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;
    }
}
相关推荐
AskHarries6 分钟前
Spring Boot集成Akka Cluster快速入门Demo
java·spring boot·后端·akka
2402_857589366 分钟前
Java免税商品购物商城:Spring Boot实现详解
java·开发语言·spring boot
Armyyyyy丶16 分钟前
spring-boot-maven-plugin插件打包和java -jar命令执行原理
java·maven·插件打包
changan27725 分钟前
(笔记自用)LeetCode:快乐数
c语言·数据结构·笔记·算法·leetcode·哈希算法
罗政35 分钟前
[附源码]SpringBoot+VUE+Java实现人脸识别系统
java·vue.js·spring boot
-XWB-41 分钟前
【Java】将一个List拆分使用线程池多线程运行
java·windows·list
陈大爷(有低保)1 小时前
题目:基于TCP/IP用DOM4j修改XML
java·服务器·tcp/ip
m0_738755921 小时前
.ideavimrc在idea打不开
java·vim·intellij-idea
超级小的大杯柠檬水1 小时前
IDEA中实现springboot热部署
java·spring boot·intellij-idea
攀小黑1 小时前
IDEA 24.1 could not autowire. No beans of ‘***‘ type found. 取消 某个类型的 警告
java·ide·intellij-idea