【Java算法刷题 15-2】 (注释详细)LeetCode - 424. 替换后的最长重复字符

90 阅读1分钟

开启掘金成长之旅!这是我参与「掘金日新计划 · 12 月更文挑战」的第 天,点击查看活动详情


题目、424. 替换后的最长重复字符

原题链接:424. 替换后的最长重复字符

题目描述

给你一个字符串 s 和一个整数 k 。你可以选择字符串中的任一字符,并将其更改为任何其他大写

英文字符。该操作最多可执行 k 次。

在执行上述操作后,返回包含相同字母的最长子字符串的长度。

示例 1:

输入:s = "ABAB", k = 2

输出:4

解释:用两个'A'替换为两个'B',反之亦然。

示例 2:

输入:s = "AABABBA", k = 1

输出:4

解释:

将中间的一个'A'替换为'B',字符串变为 "AABBBBA"。

子串 "BBBB" 有最长重复字母, 答案为 4。

解题思路

我们可以使用滑动窗口的思路解题:

首先将字符串转化为字符数组,滑动窗口的最大长度就是,窗口中的重复字符数量加上K个可替换字符数量。

将滑动窗口遍历整个字符数组,最终就能得到最长重复字符数。

具体看详细的注释与代码...

提交代码

class Solution {
    public int characterReplacement(String s, int k) {
        int len = s.length();
        if(len < 2) return len;
        char[] arr = s.toCharArray(); //将字符串字符存储进数组
        int left = 0; //左边界
        int right = 0;//右边界

        int[] sum = new int[26];//记录二十六个字符出现次数的数组
        int maxCount = 0;       //左右边界中间重复字符的数量
        int total = 0;          //最终重复字符的数量

        while(right < len){     //右边界最多抵达数组arr右边界
        
            ++sum[arr[right] - 'A']; //字符ASCII码相见,不同字符对应的作为下标
            //记录字符最大重复次数
            maxCount = Math.max(maxCount,sum[arr[right] - 'A']);
            //向右遍历
            right++;

            //若窗口中不重复字符的数量多于可以改变字符数k
            if((right - left) > (maxCount+k)){
                //记录的字符数量减去一
                --sum[arr[left]-'A'];
                //左边界向右移动一位才能继续扫描
                left++;
            }
            //总数就是最终窗口的长度
            total = Math.max(total,right-left);
        }
        return total;
        
    }
}

提交结果

在这里插入图片描述