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;
    }
}
相关推荐
星空的资源小屋17 分钟前
永久删除文件利器:Permadelete
java·javascript·人工智能
2201_7578308720 分钟前
Stream的终结方法
java·服务器·前端
今天没ID30 分钟前
Java 数组进阶操作
java
卷到起飞的数分30 分钟前
5.MyBatis持久(dao)层框架
java·数据库·mybatis
XUN4J31 分钟前
Java没有指针,那它是怎么干C语言里指针干的活的?
java
d***93537 分钟前
【Spring】Cookie和Session是什么
java·后端·spring
蜂蜜黄油呀土豆1 小时前
深入理解 Java Stream:从创建到过滤、归约、分组与聚合(带大量实战代码)
java·实战·stream流·api
一只叫煤球的猫1 小时前
从 JDK1.2 到 JDK21:ThreadLocal的进化解决了什么问题
java·后端·面试
天马行空-1 小时前
ES 精准匹配 和 模糊查询的实现方式
java·开发语言
Z***25801 小时前
Java计算机视觉
java·开发语言·计算机视觉