蓝桥杯真题 - 填充 - 题解

题目链接:https://www.lanqiao.cn/problems/3519/learning/

个人评价:难度 1 星(满星:5)

前置知识:动态规划


整体思路

  • 设 d p [ i ] dp[i] dp[i] 表示到前 i i i 个字符能替换出最多的 00 , 11 00,11 00,11 子串个数,当第 i − 1 i-1 i−1 与第 i i i 个字符至少有一个为 ? 或者两个字符相同时, d p [ i ] = d p [ i − 2 ] + 1 dp[i]=dp[i-2]+1 dp[i]=dp[i−2]+1,否则 d p [ i ] = d p [ i − 1 ] dp[i]=dp[i-1] dp[i]=dp[i−1];

过题代码

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

typedef long long LL;
const int maxn = 1000000 + 100;
int n;
char str[maxn];
int dp[maxn];

int main() {
#ifdef ExRoc
    freopen("test.txt", "r", stdin);
#endif // ExRoc
    ios::sync_with_stdio(false);

    scanf("%s", str + 1);
    n = strlen(str + 1);
    for (int i = 2; i <= n; ++i) {
        if (str[i] == '?' || str[i - 1] == '?' || str[i] == str[i - 1]) {
            dp[i] = dp[i - 2] + 1;
        } else {
            dp[i] = dp[i - 1];
        }
    }
    cout << dp[n] << endl;

    return 0;
}
相关推荐
技术蔡蔡11 分钟前
Android字节码处理-函数耗时统计揭秘
算法·面试
qing_04060319 分钟前
数据结构——二叉搜索树
数据结构·c++·二叉树·二叉搜索树
Felven33 分钟前
B. Skibidus and Ohio
算法
yonuyeung38 分钟前
代码随想录算法【Day54】
java·数据结构·算法
Ljw...43 分钟前
DeepSeek+Kimi生成高质量PPT
数据库·c++·powerpoint·ppt·deepseek
敲上瘾44 分钟前
基础dp——动态规划
java·数据结构·c++·python·算法·线性回归·动态规划
西猫雷婶1 小时前
python学智能算法(三)|模拟退火算法:深层分析
算法·机器学习·模拟退火算法
禁默1 小时前
C++之旅-C++11的深度剖析(1)
开发语言·c++
张有志_1 小时前
STL容器终极解剖:C++ vector源码级实现指南 | 从内存分配到异常安全的全流程避坑
c语言·c++·算法·开源·visual studio
SuperW1 小时前
蓝桥杯——adc的测量
蓝桥杯