eli拿到了一个仅由小写字母组成的字符串。
她想截取一段连续子串,这个子串包含至少 个相同的某个字母。
她想知道,子串的长度最小值是多少?
注:所谓连续子串,指字符串删除头部和尾部的部分字符(也可以不删除)剩下的字符串。
可以开26个前缀,然后双指针找最小
依次记录至博客,以防日后忘记
代码来自寒假训练营给的题解
神崎兰子 的代码
#include<bits/stdc++.h>
using namespace std;
int dp[200010][26]={0}; //26个前缀和数组
int main(){
int n,k,i,j;
cin>>n>>k;
string s;
cin>>s;
dp[0][s[0]-'a']=1;
for(i=1;i<n;i++){
for(j=0;j<26;j++){
dp[i][j]=dp[i-1][j];
}
dp[i][s[i]-'a']++;
}
int mi=1e9;
for(i=0;i<26;i++){
int temp=0,t2=0;
if(dp[n-1][i]<k)continue;
while(temp<n&&dp[temp][i]==0)temp++;
while(t2<n&&dp[t2][i]<k)t2++;
mi=min(mi,t2-temp+1);
for(temp++;temp<n;temp++){
if(s[temp-1]-'a'==i){
t2++;
while(t2<n&&s[t2]-'a'!=i)t2++;
if(t2==n)break;
}
mi=min(mi,t2-temp+1);
}
}
if(mi==1e9)cout<<-1;
else cout<<mi;
}
京公网安备 11010502036488号