首页 > 其他分享 >2022.10.29每日一题

2022.10.29每日一题

时间:2022-10-30 11:11:25浏览次数:67  
标签:子串 int 每日 样例 29 len cin 字符串 2022.10

Daimayuan Online Judge-01序列

题目描述

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

输入格式

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

输出格式

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

数据范围

\(0≤k≤10^6,|s|≤10^6\)

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

我们考虑使用双指针算法

  • \(k=0\):那么我们只能取全为 \(0\) 的子串,比如我们有 \(00000\),那么子串的个数应该是 \(\frac{n*(n+1)}{2}\),简单推导一下就可以了
  • \(k\ !=0\):那么我们考虑一个子串,如果其含有 \(k\) 个 \(1\),那么如果其两头有若干个 \(0\),加上这些 \(0\),仍然是符合要求的子串,从第一个 \(1\) 往前,也就是前导 \(0\) 的个数和最后一个 \(1\) 往后,后置 \(0\) 的个数的乘积就是符合要求的子串数,把所有的加起来就是答案
C++代码
#include <bits/stdc++.h>
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;
}

标签:子串,int,每日,样例,29,len,cin,字符串,2022.10
From: https://www.cnblogs.com/Cocoicobird/p/16840759.html

相关文章

  • P2299Mzc和体委的争夺战题解
    这是一道Dijkstra经典题目(裸题)P2299Mzc和体委的争夺战代码思路:Dijkstra+链式前向星+优先队列+结构体其实很简单的重点:if(vis[n])return;意思是找到了立即返回......
  • 10.29(P)
    经典例题求一元二次方程组的根:  rt  传入参数即需要的值,与给变量赋值类似......
  • 2022.10.29论文学习笔记
    本周看了一篇论文,论文的题目为:TowardsBetterNon-TreeArgumentMining:Proposition-LevelBiaffifineParsingwithTask-SpecifificParameterization,即走向更好的非树......
  • 221029 | 杂谈:CQ S 组整大活
    统计工具:VSCode因为J组烂活和无意义内容(话说这俩好像是同一个意思)太多,所以就只开S组了。总览注:统计结果表现形式为了方便,统一描述,实际搜索时统计了所有情况(不区分......
  • 10.29
    #include<stdio.h>intmain(){ chararr[0]; inti; gets(arr); for(i=0;i<9;i++) {intj; for(j=i+1;j<=8;j++) {if(arr[i]==arr[j]) {break; } } } if(arr[......
  • 2022-10-29学习内容
    1.记住密码1.1LoginMainActivity.javapackagecom.example.chapter06;importandroid.app.Activity;importandroid.content.Context;importandroid.content.Inten......
  • 【2022-10-29】前端Vue框架(四)
    一、计算属性计算属性实现首字母大小写<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>Title</title><scriptsrc="./js/vue.js"......
  • 算法学习日记10.29
    第一章基础算法(二)高精度高精度加法大整数存储:将数字存到数组里,第一个位置存个位,第二个位置存十位......从A0+B0开始算起,算个位,满十进一易错点:将数字存在字符串里......
  • 【1029】
     【LeetCode每日一题】1773.统计匹配检索规则的物品数量给你一个数组 items ,其中 items[i]=[typei,colori,namei] ,描述第 i 件物品的类型、颜色以及名称。另......
  • [2022.10.29]常用类—基本数据类型和包装类
    Java提供了八种基本数据类型:byte、short、int、long、float、double、boolean、char,每种基本类型都有其对应的类基本数据类型对应包装类byteByteshortShort......