zoukankan      html  css  js  c++  java
  • HDU 5056

    题意略。

    巧妙的尺取法。我们来枚举每个字符str[i],计算以str[i]为结尾的符合题意的串有多少个。那么我们需要处理出str[i]的左边界j,在[j,i]之间的串均为符合题意的

    串,那么str[i + 1]能否利用str[i]的处理结果呢?是可以的。str[i + 1]的左边界 >= str[i]的左边界。由此可以使用尺取。

    #include<bits/stdc++.h>
    #define maxn 100050
    using namespace std;
    typedef long long LL;
    
    char str[maxn];
    int cnt[30];
    int T,K;
    
    void init(){
        memset(cnt,0,sizeof(cnt));
    }
    
    int main(){
        scanf("%d",&T);
        while(T--){
            init();
            scanf("%s",str);
            scanf("%d",&K);
            LL len = strlen(str);
            LL ans = 0;
            int head = 0;
            for(LL i = 0;i < len;++i){
                ++cnt[str[i] - 'a'];
                ans += (i - head + 1);
                while(cnt[str[i] - 'a'] > K){
                    --cnt[str[head] - 'a'];
                    ++head;
                    ans -= 1;
                }
            }
            printf("%lld
    ",ans);
        }
        return 0;
    }
    /*
    1
    aabbccccd
    2
    */
  • 相关阅读:
    软件包管理(rpm&yum)
    文本处理三剑客之sed
    压缩归档tar
    linux文件查找find
    vim编辑器
    正则表达式
    文本处理三剑客之grep
    常用文本处理、统计工具
    文件权限管理
    用户和组管理
  • 原文地址:https://www.cnblogs.com/tiberius/p/8486700.html
Copyright © 2011-2022 走看看