今天带来的题目是:
填充
有一个长度为 n的 0101 串,其中有一些位置标记为 ?
,这些位置上可以任意填充 0
或者 1
,请问如何填充这些位置使得这个 0101 串中出现互不重叠的 00
和 11
子串最多,输出子串个数。
输入格式
输入一行包含一个字符串。
输出格式
输出一行包含一个整数表示答案。
数据范围
对于所有评测用例,1≤n≤10^6。
输入样例:
1110?0
输出样例:
2
样例解释
如果在问号处填 0
,则最多出现一个 00
和一个 11
:111000
。
解题思路:
现在来看一段字符串:
1110?0
问号有两种选择,变成1,或者变成0,变成零就能找到正确的答案,问题描述是让我们找到不重叠的数对,那么对于111或000这种情况,选择前两个数或者后两个数就行,那么我们现在有两个选择,前数对或者后数对,两者都对,那么就能变成一个贪心的问题,对于贪心的理解,我认为只要能确定一个选择是对的,就一直选下去
比如说:
1 1 1
两个选择 前两个配对,后两个配对
我们只需要知道,选第一个肯定不错,那就坚定的选第一个,然后一直选下去,一直选择正确的,这就是贪心的本质
所以这道题的题解是非常简单的,大家在自己构思的时候,肯定想了很多不同的算法,但是看到贪心的代码,就非常明亮:
题解代码:
cpp
#include<iostream>
#include<string>
using namespace std;
int main()
{
string s;
cin>>s;
int res=0;
if(s.length()==1) {
cout<<0;
return 0;
}
for(int i=0;i<s.size();i++)
{
int l=s[i],r=s[i+1];;
if(s[i]=='?'||s[i+1]=='?'||s[i]==s[i+1])
{
res++;
i++;
}
}
cout<<res;
return 0;
}
大家如果还有不懂得,就尽情来问我,对大家有帮助的话,求一个关注