开启掘金成长之旅!这是我参与「掘金日新计划 · 12 月更文挑战」的第 天,点击查看活动详情
题目、424. 替换后的最长重复字符
原题链接:424. 替换后的最长重复字符
题目描述:
给你一个字符串 s 和一个整数 k 。你可以选择字符串中的任一字符,并将其更改为任何其他大写
英文字符。该操作最多可执行 k 次。
在执行上述操作后,返回包含相同字母的最长子字符串的长度。
示例 1:
输入:s = "ABAB", k = 2
输出:4
解释:用两个'A'替换为两个'B',反之亦然。
示例 2:
输入:s = "AABABBA", k = 1
输出:4
解释:
将中间的一个'A'替换为'B',字符串变为 "AABBBBA"。
子串 "BBBB" 有最长重复字母, 答案为 4。
解题思路:
我们可以使用滑动窗口的思路解题:
首先将字符串转化为字符数组,滑动窗口的最大长度就是,窗口中的重复字符数量加上K个可替换字符数量。
将滑动窗口遍历整个字符数组,最终就能得到最长重复字符数。
具体看详细的注释与代码...
提交代码:
class Solution {
public int characterReplacement(String s, int k) {
int len = s.length();
if(len < 2) return len;
char[] arr = s.toCharArray(); //将字符串字符存储进数组
int left = 0; //左边界
int right = 0;//右边界
int[] sum = new int[26];//记录二十六个字符出现次数的数组
int maxCount = 0; //左右边界中间重复字符的数量
int total = 0; //最终重复字符的数量
while(right < len){ //右边界最多抵达数组arr右边界
++sum[arr[right] - 'A']; //字符ASCII码相见,不同字符对应的作为下标
//记录字符最大重复次数
maxCount = Math.max(maxCount,sum[arr[right] - 'A']);
//向右遍历
right++;
//若窗口中不重复字符的数量多于可以改变字符数k
if((right - left) > (maxCount+k)){
//记录的字符数量减去一
--sum[arr[left]-'A'];
//左边界向右移动一位才能继续扫描
left++;
}
//总数就是最终窗口的长度
total = Math.max(total,right-left);
}
return total;
}
}
提交结果: