2021年广东工业大学第11届腾讯杯新生程序设计竞赛 B题-过生日

这篇博客介绍了一种利用桶排序和双指针技术来寻找字符串中字符出现次数最小区间的算法。通过初始化计数桶、遍历字符串并更新桶内计数,然后使用双指针策略找到满足条件的最小区间。当没有字符出现次数达到指定阈值时,输出-1。这种方法有效地解决了涉及字符频率和区间长度的问题。
摘要由CSDN通过智能技术生成

这一题用的是桶排来判断字符出现的次数

既然涉及到最短区间 那么就要想到用min max函数来将符合题意的答案多次对比得出最优解

我采用的方法是双指针

 

#include<bits/stdc++.h>
using namespace std;
int t,k;
int main()
{
    cin>>t;
    while(t--)//多组数据输入
    {
        string s;
        int j=0;//第二指针
        int minn=1e5;//基准值
        int a[26]={0};//初始化
        cin>>s>>k;
        int ls = s.length();
        for(int i=0;i<ls;i++)//第一指针
        {
            a[s[i]-'a']++;//桶排计数
            while(a[s[i]-'a'] >= k)//若有一个桶超过了k 我们接下来要做的就是 计算他的区间长度
            {
                minn=min(minn,i-j+1); //+1是因为j会多走一格 自行模拟可得出结论
                a[s[j]-'a']--;//并不会影响后面的求解 因为第一次满的桶一定比区间长度已经大于了他后面满的可能性 这里说不清楚 我觉得你可以自行设置数据模拟 自行体会
                j++;//指针从0开始前进 直到该桶小于k为止
            }
        }
        if(minn==1e5)    printf("-1\n");//没有满桶的情况下
        else    printf("%d\n",minn);
    }
return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值