Java | Leetcode Java题解之第424题替换后的最长重复字符

题目:

题解:

java 复制代码
public class Solution {

    public int characterReplacement(String s, int k) {
        int len = s.length();
        if (len < 2) {
            return len;
        }

        char[] charArray = s.toCharArray();
        int left = 0;
        int right = 0;

        int res = 0;
        int maxCount = 0;
        int[] freq = new int[26];
        // [left, right) 内最多替换 k 个字符可以得到只有一种字符的子串
        while (right < len){
            freq[charArray[right] - 'A']++;
            // 在这里维护 maxCount,因为每一次右边界读入一个字符,字符频数增加,才会使得 maxCount 增加
            maxCount = Math.max(maxCount, freq[charArray[right] - 'A']);
            right++;

            if (right - left > maxCount + k){
              	// 说明此时 k 不够用
                // 把其它不是最多出现的字符替换以后,都不能填满这个滑动的窗口,这个时候须要考虑左边界向右移动
                // 移出滑动窗口的时候,频数数组须要相应地做减法
                freq[charArray[left] - 'A']--;
                left++;
            }
            res = Math.max(res, right - left);
        }
        return res;
    }
}
相关推荐
iAkuya1 分钟前
(leetcode)力扣100 19螺旋矩阵(方向数组/边界把控)
算法·leetcode·矩阵
培培说证4 分钟前
2026大专Java开发工程师,考什么证加分?
java·开发语言·python
爱编程的小吴5 分钟前
【力扣练习题】热题100道【哈希】 最长连续序列
算法·leetcode·职场和发展
qq_336313935 分钟前
java基础-方法引用
java·开发语言·算法
总是学不会.8 分钟前
【JUC编程】一、线程的基础概念
java·开发语言·jvm
由之18 分钟前
Spring事件监听机制简单使用
java·spring
小鸡吃米…20 分钟前
Python - 类属性
java·前端·python
沉下去,苦磨练!22 分钟前
计算一个字符串在另一个字符串中出现次数
java·开发语言
Li_7695321 小时前
Redis —— (五)
java·redis·后端·spring
派大鑫wink1 小时前
【Day7】构造方法与 this 关键字:初始化对象的正确姿势
java·开发语言