今天带来的题目是:
填充
有一个长度为 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
两个选择 前两个配对,后两个配对
我们只需要知道,选第一个肯定不错,那就坚定的选第一个,然后一直选下去,一直选择正确的,这就是贪心的本质

文章讨论了如何在给定的0101字符串中,通过填充?位置以获得最多数量的不重叠00和11子串,利用贪心策略解决此问题。解题的关键在于选择正确的数对组合,通过编程实现,如C++代码所示。
最低0.47元/天 解锁文章





