今天带来的题目是:
有一个长度为?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
两个选择 前两个配对,后两个配对
我们只需要知道,选第一个肯定不错,那就坚定的选第一个,然后一直选下去,一直选择正确的,这就是贪心的本质
#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;
}
大家如果还有不懂得,就尽情来问我,对大家有帮助的话,求一个关注