算法练习帖--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; }
赞 (0)