打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
算法练习帖--62--替换后的最长重复字符(Java)

替换后的最长重复字符

一、题目简介

给你一个仅由大写英文字母组成的字符串,你可以将任意位置上的字符替换成另外的字符,总共可最多替换 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;    }
来源:https://www.icode9.com/content-1-843201.html
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
514,双指针解替换后的最长重复字符
linux下面文件字符操作总结函数集锦
C和指针之字符串编程练习9(在参数1中查找匹配参数2额任意字符)
LeetCode 680.验证回文字符串Ⅱ
【小Y学算法】⚡️每日LeetCode打卡⚡️——3.无重复字符的最长子串
野路子搞算法 · 让算法可视化《leetcode03.无重复字符的最长子串》
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服