蓝桥杯历届真题 填充#贪心算法

文章目录


题目链接

题目解读

题目描述

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

输入一行包含一个字符串。
输出格式

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

1110?0
样例输出

2
提示

如果在问号处填 0 ,则最多出现一个 00 和一个 11:111000 。

对于所有评测用例,1 ≤ n ≤ 1000000 。

思路

看到最大最小可以考虑一手贪心算法,然后直接猜出来一个规律。

然后去找一个反例证明其是错的,如果证明不出来,那么它就是对的!

贪心思路 : 从头往后枚举,如果能发生"配对"那么答案加1

配对儿 : 如果当前字符和下一个字符一致,或者两个连续的字符里出现一个问号,那么也可以配对儿成功。

AC CODE

cpp 复制代码
#include<bits/stdc++.h>

using namespace std;

int main(){
	string s;
	cin >> s;
	
	int res=0;
	for(int i=0; i<s.size()-1; i++){
		char a=s[i];
		char b=s[i+1];
		
		if(a==b || a=='?' || b=='?'){
			res++;
			i++;	
		}
	} 
	
	cout << res;
	
	return 0;
}

参考

acwing 算法平台

注意

贪心算法证明难度较大,可以猜出来一个规律后直接使用,不需要严格证明其正确性


🌻编写本篇文章目的是笔者想以输出的形式进行学习,顺便记录学习点滴🌻

🌹 如果本篇文章对你有帮助的话那就点个赞吧👍🌹

😇 本篇文章可能存在多处不足,如有修改意见,可以私信或者评论我哦 😇


相关推荐
triticale9 小时前
【蓝桥杯】P12165 [蓝桥杯 2025 省 C/Java A] 最短距离
java·蓝桥杯
一只鱼^_11 小时前
第十六届蓝桥杯大赛软件赛省赛 C/C++ 大学B组 [京津冀]
c语言·数据结构·c++·算法·贪心算法·蓝桥杯·动态规划
binary思维12 小时前
C语言实现贪心算法
c语言·算法·贪心算法
wuqingshun31415913 小时前
蓝桥杯 3. 密码脱落
c++·算法·职场和发展·蓝桥杯·深度优先
菜鸟小白:长岛icetea13 小时前
第十六届蓝桥杯网安初赛wp
蓝桥杯·ctf
ALe要立志成为web糕手14 小时前
第十六周蓝桥杯2025网络安全赛道
安全·web安全·网络安全·蓝桥杯
CHTXRT16 小时前
2025第十六届蓝桥杯大赛(软件赛)网络安全赛 Writeup
c语言·网络·web安全·网络安全·蓝桥杯·wireshark
梁下轻语的秋缘1 天前
每日c/c++题 备战蓝桥杯(P1049 [NOIP 2001 普及组] 装箱问题)
c语言·c++·学习·蓝桥杯
wuqingshun3141591 天前
蓝桥杯 5. 交换瓶子
数据结构·c++·算法·职场和发展·蓝桥杯
程序员-King.1 天前
day49—双指针+贪心—验证回文串(LeetCode-680)
算法·leetcode·贪心算法·双指针