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; }