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;
    }
}
相关推荐
好家伙VCC13 小时前
**发散创新:基于Rust的轻量级权限管理库设计与开源许可证实践**在现代分布式系统中,**权限控制(RBAC
java·开发语言·python·rust·开源
m0_7190841113 小时前
天机学堂aaaa
java
孙鹏宇.13 小时前
左值右值.
java·开发语言
XDHCOM13 小时前
Redis节点故障自动恢复机制详解,如何快速抢救故障节点,确保数据不丢失?
java·数据库·redis
风吹迎面入袖凉13 小时前
【Redis】Redisson分布式锁原理
java·服务器·开发语言
QCzblack13 小时前
BugKu BUUCTF ——Reverse
java·前端·数据库
Orange_sparkle13 小时前
learn claude code学习记录-S02
java·python·学习
李白你好14 小时前
Java GUI-未授权漏洞检测工具
java·开发语言
aq553560014 小时前
四大编程语言对比:PHP、Python、Java、易语言
java·python·php
成为大佬先秃头15 小时前
前后分离项目:整合JWT+Shiro
java·springboot·shiro·jwt