每日一道算法题day-two(备战蓝桥杯)

今天带来的题目是:

填充

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

输入格式

输入一行包含一个字符串。

输出格式

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

数据范围

对于所有评测用例,1≤n≤10^6。

输入样例:
1110?0
输出样例:
2
样例解释

如果在问号处填 0,则最多出现一个 00 和一个 11111000

解题思路:

现在来看一段字符串:
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;
}

大家如果还有不懂得,就尽情来问我,对大家有帮助的话,求一个关注

相关推荐

  1. 每日算法day-two备战

    2024-01-05 15:42:03       45 阅读
  2. 备战每日

    2024-01-05 15:42:03       25 阅读
  3. 每日(Dijkstra最短路算法

    2024-01-05 15:42:03       18 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-05 15:42:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-05 15:42:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-05 15:42:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-05 15:42:03       18 阅读

热门阅读

  1. Qt 连接 Mysql

    2024-01-05 15:42:03       40 阅读
  2. CSS中的浏览器支持

    2024-01-05 15:42:03       39 阅读
  3. python基于flask实现一个文本问答系统

    2024-01-05 15:42:03       34 阅读
  4. git 使用场景 --amend 提交

    2024-01-05 15:42:03       41 阅读
  5. SpringCloud

    2024-01-05 15:42:03       32 阅读
  6. C#对象初始化器

    2024-01-05 15:42:03       41 阅读
  7. C语言,打印一个数二进制的偶数位和奇数位。

    2024-01-05 15:42:03       33 阅读
  8. C++完成Connect连接数据的接口和测试

    2024-01-05 15:42:03       41 阅读
  9. 服务器的丢包率高怎么办

    2024-01-05 15:42:03       38 阅读
  10. jquery获取子元素的一些方法

    2024-01-05 15:42:03       36 阅读