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;
    }
}
相关推荐
2601_94981668几秒前
使用rustDesk搭建私有远程桌面
java
Frostnova丶3 分钟前
LeetCode 735 & 2751.栈模拟碰撞问题详解
算法·leetcode
看见代码就想敲8 分钟前
java学习之(Maven pom.xml 详细讲解)
java·学习·maven
糖炒栗子032616 分钟前
图片加水印与 EXIF 保留方案
java
tongxh42316 分钟前
Spring Boot问题总结
java·spring boot·后端
wfbcg21 分钟前
每日算法练习:LeetCode 28. 找出字符串中第一个匹配项的下标 ✅
算法·leetcode·职场和发展
Chan1622 分钟前
SpringAI:RAG 最佳实践与调优
java·spring boot·ai·java-ee·intellij-idea·rag·springai
odng23 分钟前
Windsurf / Codex 默认只显示 3 个最近任务,如何改成 100 个
java
m0_7167652325 分钟前
C++巩固案例--通讯录管理系统详解
java·开发语言·c++·经验分享·学习·青少年编程·visual studio
Predestination王瀞潞26 分钟前
Java EE3-我独自整合(第三章:Spring DI 入门案例)
java·spring·java-ee