京东笔试8-27号 最后一题(漂亮数)

输入一个n
输出长度为n的,只包括小写字母的,至少有两个red的字符串的数量。
解决方案:用总的字符串数量 减去 不包括一个red的,再减去包括一个red的字符串的数量
dp[i][j]表示前i个字符,其中第i个字符已经匹配到red的第j位了的字符串个数,例如dp[6][2]表示前6个字符,最后已经匹配到re了的字符串个数,即以re结尾的字符串个数。
代码如下:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 1e6 + 10;
const int mod = 1e9 + 7;
ll dp[N][4];
void init(int n){
	dp[0][0] = 1;
	for(int i = 1; i <= n; i ++){
		dp[i][0] = (dp[i - 1][0] * 25 % mod + dp[i - 1][1] * 24 % mod + dp[i - 1][2] * 24 % mod) % mod;
		dp[i][1] = (dp[i - 1][0] + dp[i - 1][1] + dp[i - 1][2]) % mod;
		dp[i][2] = dp[i - 1][1];
	}
}
int main()
{
	int n;
	cin >> n;
	ll ans = 1;
	for(int i = 1; i <= n; i ++){
		ans = ans * 26 % mod;
	}
	init(n);
	ans = (ans - (dp[n][0] + dp[n][1] + dp[n][2]) % mod + mod) % mod;
	for(int i = 1; i <= n - 2; i ++){
		ll left = (dp[i - 1][0] + dp[i - 1][1] + dp[i - 1][2]) % mod;
		ll right = (dp[n - i - 2][0] + dp[n - i - 2][1] + dp[n - i - 2][2]) % mod;
		ans = (ans - left * right % mod + mod) % mod;
	}
	cout << ans << endl;
	return 0;
}


#京东笔试##dp##笔试##京东#
全部评论
dp的ij没太看明白,可以举个例子吗大佬
点赞 回复 分享
发布于 2022-08-28 10:49 浙江

相关推荐

评论
6
13
分享

创作者周榜

更多
正在热议
更多
# 春招至今,你的战绩如何? #
8028次浏览 74人参与
# 你的实习产出是真实的还是包装的? #
1491次浏览 37人参与
# 米连集团26产品管培生项目 #
5301次浏览 213人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
7259次浏览 40人参与
# 简历第一个项目做什么 #
31428次浏览 318人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
186693次浏览 1118人参与
# MiniMax求职进展汇总 #
23494次浏览 305人参与
# 研究所笔面经互助 #
118827次浏览 577人参与
# 重来一次,我还会选择这个专业吗 #
433194次浏览 3924人参与
# 简历中的项目经历要怎么写? #
309803次浏览 4174人参与
# 面试紧张时你会有什么表现? #
30450次浏览 188人参与
# AI时代,哪些岗位最容易被淘汰 #
63087次浏览 770人参与
# 正在春招的你,也参与了去年秋招吗? #
362979次浏览 2635人参与
# 你怎么看待AI面试 #
179643次浏览 1203人参与
# 职能管理面试记录 #
10765次浏览 59人参与
# 网易游戏笔试 #
6420次浏览 83人参与
# 腾讯音乐求职进展汇总 #
160510次浏览 1107人参与
# 校招笔试 #
469031次浏览 2960人参与
# 把自己当AI,现在最消耗你token的问题是什么? #
7129次浏览 157人参与
# 你觉得通信/硬件有必要实习吗? #
155421次浏览 1065人参与
# 小红书求职进展汇总 #
227003次浏览 1357人参与
# 从哪些方向判断这个offer值不值得去? #
56720次浏览 357人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务