今天带来的题目是:
填充
有一个长度为 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
两个选择 前两个配对,