蓝桥杯真题 - 填充 - 题解

题目链接: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;
}
相关推荐
minji...4 分钟前
C++ 详细讲解vector类
开发语言·c++
颖川守一13 分钟前
c6-类和对象-对象特征-类对象做对象成员
c++
山河君15 分钟前
webrtc之高通滤波——HighPassFilter源码及原理分析
算法·音视频·webrtc·信号处理
星辰大海的精灵16 分钟前
SpringBoot与Quartz整合,实现订单自动取消功能
java·后端·算法
data myth21 分钟前
力扣1210. 穿过迷宫的最少移动次数 详解
算法·leetcode·职场和发展
惯导马工30 分钟前
【论文导读】AI-Assisted Fatigue and Stamina Control for Performance Sports on IMU-Gene
深度学习·算法
tongsound31 分钟前
ros2 lifcycle介绍
linux·c++
沐怡旸36 分钟前
【算法--链表】109.有序链表转换二叉搜索树--通俗讲解
算法·面试
努力的小钟40 分钟前
C++全局变量初始化流程详解
c++
小苏兮42 分钟前
【C++】类与对象(下)
开发语言·c++·学习