leetCode No.424 Longest Repeating Character Replacement

题目

Given a string that consists of only uppercase English letters, you can replace any letter in the string with another letter at most k times. Find the length of a longest substring containing all repeating letters you can get after performing the above operations.

Note:
Both the string’s length and k will not exceed 104.

Example 1:

Input:
s = "ABAB", k = 2

Output:
4

Explanation:
Replace the two 'A's with two 'B's or vice versa.

Example 2:

Input:
s = "AABABBA", k = 1

Output:
4

Explanation:
Replace the one 'A' in the middle with 'B' and form "AABBBBA".
The substring "BBBB" has the longest repeating letters, which is 4.

相似题目: (H) Longest Substring with At Most K Distinct Characters

题意

给定一个只包含大写字母的字符串,给予k次交换的机会,寻找字符串中最长的连续相同的字母子串,当字母不一样的时候可以使用交换次数,将字母变为一样的。

解题思路

最开始的时候的算法跟其他几个博主的想法也差不多。从最左端开始找与开始字母一样的字母,若不一样且k次交换没有用完,就继续向后找,直到k次用完,记录当前的长度。然后从最左端后一个开始找,用相同的方法找长度。最后取最长的长度。同时,当当前最长的长度已经大于剩余的字符串长度时,可以结束查找。
这种方法在样例"ABBB",2 测试时出错了,因为是从最左向右找,程序并不能考虑BBBB 这种情况。
那么就改一下程序,用同样的查找方法,在从左向右查找的程序之外加上从右向左的查找。
这种方法在"BAAAB",2 这种情况中还是会出错。
在discuss中查看到的正解十分巧妙,使用的是滑窗算法。
即定义end和start指针,end - start即为窗体的长度,要保证该窗体中:窗体长度 - 最多字母个数 > k。窗体长度即为最多变换k次之后,最长的相同字母字符串。

代码

public class Solution {
    public int characterReplacement(String s, int k) {
        int l = s.length();
        int[] count = new int[26];
        int start = 0;
        int max = 0;
        int res = 0;
        for (int end = 0; end < l; end++) { max = Math.max(max, ++count[s.charAt(end) - 'A']);
            while (end - start + 1 - max > k) { count[s.charAt(start) - 'A']--;
                start++;
            }
            res = Math.max(res, end - start + 1);
        }
        return res;
    }
}

相关链接

原题
全部题目题解

你可能感兴趣的:(LeetCode)