【贪心】第十四届蓝桥杯省赛C++ / Java / Python C组《填充》(C++)

【题目描述】

有一个长度为 n 的 01 串,其中有一些位置标记为 ?,这些位置上可以任意填充 0 或者 1,请问如何填充这些位置使得这个 01 串中出现互不重叠的 00 和 11 子串最多,输出子串个数。

【输入格式】

输入一行包含一个字符串。

【输出格式】

输出一行包含一个整数表示答案。

【数据范围】

对于所有评测用例,1≤n≤10的6次方。

【输入样例】

1110?0

【输出样例】

2

【样例解释】

如果在问号处填 0,则最多出现一个 00 和一个 11111000

【代码】

cpp 复制代码
#include <iostream>
#include <cstring>
#include <algorithm>

using namespace std;

int main()
{
    string s;
    cin >> s;

    int res = 0;
    for (int i = 0; i + 1 < s.size(); i ++ )
        if (s[i] == s[i + 1] || s[i] == '?' || s[i + 1] == '?')
        {
            res ++ ;
            i ++ ;
        }

    cout << res << endl;
    return 0;
}
相关推荐
chenyuhao20243 分钟前
Linux系统编程:进程控制
linux·运维·服务器·开发语言·c++·后端
JiaJZhong7 分钟前
560. 和为 K 的子数组
数据结构·算法
落羽的落羽8 分钟前
【Linux系统】进程终止、进程等待与进程替换的概念与实现
linux·服务器·c++·人工智能·深度学习·机器学习·游戏引擎
小年糕是糕手9 分钟前
【C++】模板初阶
java·开发语言·javascript·数据结构·c++·算法·leetcode
脏脏a12 分钟前
C++ 字符串处理利器:STL string 保姆级入门教程
开发语言·c++
AndrewHZ1 小时前
【遥感图像入门】遥感图像专用去噪算法:核心方案与实战(PyTorch代码)
pytorch·算法·计算机视觉·cv·遥感图像·高分辨率·去噪算法
qq_479875432 小时前
C++ 网络编程中的 Protobuf 消息分发 (Dispatcher) 设计模式
网络·c++·设计模式
前端小L2 小时前
回溯算法专题(八):精细化切割——还原合法的「IP 地址」
数据结构·算法
Tandy12356_2 小时前
手写TCP/IP协议——IP层输出处理
c语言·网络·c++·tcp/ip·计算机网络
博语小屋2 小时前
实现简单日志
linux·服务器·数据库·c++