【每日一题】25.「火」皇家烈焰 (字符串DP)
补题链接:Here
转移方程的具体含义我在代码注释里写出来了, 很好理解
这道题的难点在于如何表示状态, 一旦找到状态表示方法
只要根据题意做转移就行了
最后的答案就是
即最后一个位置有火的方案数加上最后一个位置没有火的方案数
注意不要忘了一开始的初始化
using ll = long long;
const int mod = 1e9 + 7, N = 1e6 + 10;
ll dp[N][2][2];
void solve() {
string s; cin >> s;
s = " " + s;
int n = s.size() - 1;
dp[0][0][0] = dp[0][0][1] = 1;
for (int i = 1; i <= n; i++) {
if (s[i] == '0') { // 当前和左右都无
dp[i][0][0] += dp[i - 1][0][0], dp[i][0][0] %= mod;
}
else if (s[i] == '1') { // 当前无 左右 有一个
dp[i][0][0] += dp[i - 1][1][0]; dp[i][0][0] %= mod; // 左有
dp[i][0][1] += dp[i - 1][0][0], dp[i][0][1] %= mod; // 右有
}
else if (s[i] == '2') { // 当前无 左右均有
dp[i][0][1] += dp[i - 1][1][1], dp[i][0][1] %= mod; // 左右有
}
else if (s[i] == '*') { // 当前有 左右任意
dp[i][1][0] += (dp[i - 1][0][1] + dp[i - 1][1][1]),
dp[i][1][0] %= mod; // 当前有 右无 然后 左有或者没有
dp[i][1][1] += (dp[i - 1][0][1] + dp[i - 1][1][1]),
dp[i][1][1] %= mod; // 当前有 右有 然后 左有或者没有
}
else if (s[i] == '?') { // 当前任意
dp[i][1][0] += (dp[i - 1][0][1] + dp[i - 1][1][1]),
dp[i][1][0] %= mod; // 当前为火 右无
dp[i][1][1] += (dp[i - 1][0][1] + dp[i - 1][1][1]),
dp[i][1][1] %= mod; // 当前和右 为火
dp[i][0][1] += (dp[i - 1][0][0] + dp[i - 1][1][0]),
dp[i][0][1] %= mod; // 当前无 右火
dp[i][0][0] += (dp[i - 1][0][0] + dp[i - 1][1][0]),
dp[i][0][0] %= mod; // 当前无 右无
}
}
cout << (dp[n][1][0] + dp[n][0][0]) % mod <<
"\n"; // 最后一格有 和 无的方案
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· 分享4款.NET开源、免费、实用的商城系统
· Obsidian + DeepSeek:免费 AI 助力你的知识管理,让你的笔记飞起来!
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 全程不用写代码,我用AI程序员写了一个飞机大战