码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 2022.10.29每日一题


    Daimayuan Online Judge-01序列

    题目描述

    我们称一个字符串为好字符串,指这个字符串中只包含 0 和 1。
    现在有一个好字符串,求这个字符串中 1 恰好出现 k 次的子串有多少个。

    输入格式

    第一行给出一个数字 k,表示子串中 1 的个数。
    第二行给出好字符串。

    输出格式

    输出一个整数,表示好字符串中有多少个符合条件的子串。

    数据范围

    0≤k≤106,|s|≤106

    样例输入1
    1
    1010
    
    样例输出1
    6
    
    样例输入2
    2
    01010
    
    样例输出2
    4
    
    解题思路

    我们考虑使用双指针算法

    • k=0:那么我们只能取全为 0 的子串,比如我们有 00000,那么子串的个数应该是 n∗(n+1)2,简单推导一下就可以了
    • k !=0:那么我们考虑一个子串,如果其含有 k 个 1,那么如果其两头有若干个 0,加上这些 0,仍然是符合要求的子串,从第一个 1 往前,也就是前导 0 的个数和最后一个 1 往后,后置 0 的个数的乘积就是符合要求的子串数,把所有的加起来就是答案
    C++代码
    #include 
    using namespace std;
    typedef long long LL;
    
    int k;
    string s;
    
    int main()
    {
        ios_base::sync_with_stdio(false);
        cin.tie(nullptr);
        cout.tie(nullptr);
        cin >> k;
        cin >> s;
        int len = s.size();
        int cnt = 0;
        LL res  = 0;
        if(k == 0)
        {
            for(int i = 0; i < len; i ++)
            {
                if(s[i] - '0') continue;
                int j = i;
                while(s[j] - '0' == 0 && j < len)
                {
                    j ++;
                }
                // cout << i << ' ' << j << endl;
                res += ((LL)(j - i + 1) * (LL)(j - i) / 2);
                i = j;
            }
            cout << res << endl;
            return 0;
        }
        for(int i = 0, j = 0; i < len; i ++)
        {
            while(j < len)
            {
                if(s[j] == '1')
                    cnt ++;
                if(cnt == k)
                    break;
                j ++;
            }
            if(cnt == k)
            {
                int ed = j + 1;
                while(ed < len && s[ed] != '1')
                    ed ++;
                int c = ed - j; // 后置0
                while(i < len && s[i] != '1')
                {
                    i ++;
                    res += c;
                }
                res += c;
                j ++;
                cnt --;
            }
        }
        cout << res << endl;
        return 0;
    }
    
  • 相关阅读:
    Oracle/PLSQL: CharToRowid Function
    244_C++_两个不同文件,其中一个通过地址,给另一个文件赋值,另一个文件通过&“引用“接受赋值
    JAVA毕业设计剧院售票系统计算机源码+lw文档+系统+调试部署+数据库
    细胞焦亡+单细胞RNA测序联合分析,搭配实验验证,轻松发到5分+。
    操作系统学习笔记5 | 用户级线程 && 内核级线程
    SpringBoot实现分页查询
    spring bean实例化过程及顺序
    算法打卡day48|动态规划篇16| Leetcode 583. 两个字符串的删除操作、72. 编辑距离
    ABeam中国2022社招 | ABeam旗下德硕管理咨询(深圳)有限公司
    网络安全:windows批处理写病毒的一些基本命令.
  • 原文地址:https://www.cnblogs.com/Cocoicobird/p/16840759.html
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号