美团2024秋招编程题:小美的red子序列数量之和

2024-09-01 01:20

本文主要是介绍美团2024秋招编程题:小美的red子序列数量之和,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目为:

小美有一个字符串,小美想知道这个字符串的所有连续子串中,red 子序列的数量之和。
子串是指从原字符串中,连续的选择一段字符组成的新字符串。
定义 red 子序列为从原字符串中从左到右依次取出r、e和d组成的新字符串。

输入描述

第一行输入一个长度不超过10^5、且仅由小写字母构成的字符串s,代表小美的字符串。

输出描述

在一行上输出一个整数,代表所有子串中 red 子序列的数量之和。由于答案可能很大,请将答案对(10^9十7)取模后输出。

示例 1
输入

redd

输出

3

说明

在 red 子串中,有1个red 子序列;
在 redd 子串中,有 2个red 子序列:

接替代码:

def count_red_subsequences(s):MOD = 10**9 + 7n = len(s)red_count = 0for j in range(n-2):dp = [[0] * 3 for _ in range(n)]for i in range(j, n):if s[i] == 'r':dp[i][0] = 1 + (dp[i-1][0] if i > 0 else 0)if s[i] == 'e':if i > 0:dp[i][1] = dp[i-1][1] + dp[i-1][0]if s[i] == 'd':if i > 0:dp[i][2] = dp[i-1][2] + dp[i-1][1]if i > 0:# dp[i][0] = (dp[i][0] + dp[i-1][0]) % MODdp[i][2] = (dp[i][2] + dp[i-1][2]) % MODif s[i] == 'd':red_count = (red_count + dp[i][2]) % MODreturn red_count

题解

dp[i][0]表示以第i个字符结尾的子串钟r的数量
dp[i][1]表示以第i个字符结尾的子串钟re的数量
dp[i][2]表示以第i个字符结尾的子串钟red的数量

两层for循环遍历,计算第j个字符开始第i个字符结尾的子串钟,red子序列的全部数量。
dp[i][2] = (dp[i][2] + dp[i-1][2]) % MOD重点是这句计算了s[j:i]中,s[j:i-1]red子序列加上s[j:i]red子序列之和。这样就成功计算了所有连续子串中的red子序列之和。

这篇关于美团2024秋招编程题:小美的red子序列数量之和的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1125540

相关文章

利用Python实现时间序列动量策略

《利用Python实现时间序列动量策略》时间序列动量策略作为量化交易领域中最为持久且被深入研究的策略类型之一,其核心理念相对简明:对于显示上升趋势的资产建立多头头寸,对于呈现下降趋势的资产建立空头头寸... 目录引言传统策略面临的风险管理挑战波动率调整机制:实现风险标准化策略实施的技术细节波动率调整的战略价

MySQL精准控制Binlog日志数量的三种方案

《MySQL精准控制Binlog日志数量的三种方案》作为数据库管理员,你是否经常为服务器磁盘爆满而抓狂?Binlog就像数据库的“黑匣子”,默默记录着每一次数据变动,但若放任不管,几天内这些日志文件就... 目录 一招修改配置文件:永久生效的控制术1.定位my.cnf文件2.添加核心参数不重启热更新:高手应

PostgreSQL 序列(Sequence) 与 Oracle 序列对比差异分析

《PostgreSQL序列(Sequence)与Oracle序列对比差异分析》PostgreSQL和Oracle都提供了序列(Sequence)功能,但在实现细节和使用方式上存在一些重要差异,... 目录PostgreSQL 序列(Sequence) 与 oracle 序列对比一 基本语法对比1.1 创建序

Python 异步编程 asyncio简介及基本用法

《Python异步编程asyncio简介及基本用法》asyncio是Python的一个库,用于编写并发代码,使用协程、任务和Futures来处理I/O密集型和高延迟操作,本文给大家介绍Python... 目录1、asyncio是什么IO密集型任务特征2、怎么用1、基本用法2、关键字 async1、async

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque