蓝桥杯真题 - 填充 - 题解

题目链接: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;
}
相关推荐
郝学胜-神的一滴16 小时前
Qt QPushButton 样式完全指南:从基础到高级实现
linux·开发语言·c++·qt·程序人生
⠀One0ne16 小时前
【C++ 面试题】内存对齐
c++
蓝色汪洋16 小时前
xtu oj环--唉
算法
Algo-hx16 小时前
数据结构入门 (十):“左小右大”的秩序 —— 深入二叉搜索树
数据结构·算法
Elias不吃糖16 小时前
NebulaChat 框架学习笔记:原子变量与左值引用的工程应用
c++·学习
Theliars16 小时前
Ubuntu 上使用 VSCode 调试 C++ (CMake 项目) 指南
c++·vscode·ubuntu·cmake
mjhcsp16 小时前
C++ map 容器:有序关联容器的深度解析与实战
开发语言·c++·map
将编程培养成爱好16 小时前
C++ 设计模式《账本事故:当备份被删光那天》
开发语言·c++·设计模式·备忘录模式
努力学算法的蒟蒻16 小时前
day11(11.11)——leetcode面试经典150
算法·leetcode·面试
im_AMBER16 小时前
Leetcode 51
笔记·学习·算法·leetcode·深度优先