当前位置 博文首页 > Inmaturity_7的博客:算法练习帖--62--替换后的最长重复字符(Jav

    Inmaturity_7的博客:算法练习帖--62--替换后的最长重复字符(Jav

    作者:[db:作者] 时间:2021-07-16 21:50

    替换后的最长重复字符

    一、题目简介

    给你一个仅由大写英文字母组成的字符串,你可以将任意位置上的字符替换成另外的字符,总共可最多替换 k 次。在执行上述操作后,找到包含重复字母的最长子串的长度。

    注意:字符串长度 和 k 不会超过 104。
    (题目来源:力扣(LeetCode))

    示例 1:
    输入:s = "ABAB", k = 2
    输出:4
    解释:用两个'A'替换为两个'B',反之亦然。
    
    示例 2:
    输入:s = "AABABBA", k = 1
    输出:4
    解释:
    将中间的一个'A'替换为'B',字符串变为 "AABBBBA"。
    子串 "BBBB" 有最长重复字母, 答案为 4。
    

    二、解决方法

    1. 暴力美学

    public int characterReplacement(String s, int k) {
            char[] chars = s.toCharArray();
            int maxL=0;//最大长度
            for (int i = 0; i < chars.length; i++) {
                int c=chars[i];//获取当前字符
                int right=i;//右指针
                int left=i;//左指针
                int time=k;//当前可替换次数
                while(right+1<chars.length&&(c==chars[right+1]||--time>=0)){
                    //如果后一位和当前字符相等,或者我们可以替换之让其相等(次数要减少,最大为k)
                    right++;
                }
                while(left>=1&&(c==chars[left-1]||--time>=0)){
                    //如果前一位和当前字符相等,或者我们可以替换之让其相等(次数要减少,最大为k)
                    left--;
                }
                maxL=Math.max(maxL,right-left+1);//获取最大值
            }
            return maxL;
        }
    

    2. 双指针

    public static int characterReplacement(String s, int k) {
            //AABABBA
            int[] num = new int[26];//因为只含大写字母,创建26大小的数组记录
            int n = s.length();
            int maxn = 0;
            int left = 0, right = 0;//左右指针
            while (right < n) {
                num[s.charAt(right) - 'A']++;//当前字符数++
                maxn = Math.max(maxn, num[s.charAt(right) - 'A']);//获取当前窗口的最大字符数(而且要和历史窗口值比较)
                if (right - left + 1 - maxn > k) {
                    //如果不满足替换情况,也就是替换窗口中的字符得不到最大字符串
                    //则左指针--
                    num[s.charAt(left) - 'A']--;
                    left++;
                }
                //右指针++,一直向右推进
                right++;
            }
            return right - left;
        }
    
    cs