public int characterReplacement(String s, int k) {
char[] chars = s.toCharArray();
int maxL=0;//最大长度
for (int i = 0; i < chars.length; i ) {
int c=chars[i];//获取当前字符
int right=i;//右指针
int left=i;//左指针
int time=k;//当前可替换次数
while(right 1<chars.length&&(c==chars[right 1]||--time>=0)){
//如果后一位和当前字符相等,或者我们可以替换之让其相等(次数要减少,最大为k)
right ;
}
while(left>=1&&(c==chars[left-1]||--time>=0)){
//如果前一位和当前字符相等,或者我们可以替换之让其相等(次数要减少,最大为k)
left--;
}
maxL=Math.max(maxL,right-left 1);//获取最大值
}
return maxL;
}
2. 双指针
public static int characterReplacement(String s, int k) {
//AABABBA
int[] num = new int[26];//因为只含大写字母,创建26大小的数组记录
int n = s.length();
int maxn = 0;
int left = 0, right = 0;//左右指针
while (right < n) {
num[s.charAt(right) - 'A'] ;//当前字符数
maxn = Math.max(maxn, num[s.charAt(right) - 'A']);//获取当前窗口的最大字符数(而且要和历史窗口值比较)
if (right - left 1 - maxn > k) {
//如果不满足替换情况,也就是替换窗口中的字符得不到最大字符串
//则左指针--
num[s.charAt(left) - 'A']--;
left ;
}
//右指针 ,一直向右推进
right ;
}
return right - left;
}