424. Longest Repeating Character Replacement
以最左边为开始,往右遍历,不一样的个数大于K的时候停止,回到第一个不一样的地方,以它为开始,继续。。
用QUEUE记录每次不一样的INDEX,以便下一个遍历开始,
从左往右,从右往左各来一次。。加上各种剪枝情况,比如未遍历的数量<剩余K的数量,比如已经记录过某个INDEX了。。
然后TLE了。。。最后放TLE的方法。。不知道有什么意义。。
上面的做法是左右各来一次,那是否可以使用滑窗呢。。
然后没做出来。。看了讨论区。。果然是滑窗。。
思路:
统计当前滑窗内最多的字母,窗口宽度 - 最多字母数量 <= K,就可以继续尝试扩大窗口,R++。 否则缩小,L++。
比我一开始的那个傻逼办法的改进在于,自动转换字母,我那个必须记录不同字母,比如AAABBBBB当B多的时候,必须退回到第一个B,重新遍历。。而且不用反向再来一次。
至少。。我。。猜对。。滑。。滑窗。。了。。
public class Solution
{
public int characterReplacement(String s, int k)
{
int[] letter = new int[26];
int l = 0;
int most = ++letter[s.charAt(0) - 'A'];
int res = 1;
for(int r = 1; r < s.length();r++)
{
most = Math.max(most,++letter[s.charAt(r) - 'A']);
if(most + k < r - l + 1) // can't maintain this size of window
{
letter[s.charAt(l++)-'A']--;
}
res = Math.max(res,r-l+1);
}
return res;
}
}
二刷。
这个题刚做的,还有印象,滑窗。
但是凭印象做完,回头看这个做法非常巧妙。
我还记得一开始的思路是滑窗,但是做不出来,当时的想法是:
最多的字母 + Others(k) = Length
每次滑窗扩大都需要统计最多的字母,然后相应地要改变Others(或者不改变),再和K比较,决定窗口的左端是否缩进,然后缩进又会减少相应的字母,又要重新判断最多的字母。。。此时右端保持不动。。。
这里忽略了一个问题就是,缩进的目的有2个,一个是通过减少不一样的字母(others)来满足others <= k;或者通过改变最多的字母(most)来满足others <= k,因为只有在满足的情况下我们才会更新res的最大值。 简而言之,通过不停地让窗口左端缩进,目的只有一个others <= k,一旦这个满足我们就可以update res,但是,既然我们都他妈缩进了,肯定比前面的结果小,还更新个鸡巴。。
这里巧妙就巧妙在,左边缩进的同时右边扩大,因为窗口再变小即使满足others <= k,窗口大小也是小于res的,so why bother...and who gives a shit..所以直接右边扩大就行了。。
一开始的想法是尽量满足others <= k的时候判断窗口大小;
后来的做法是保持窗口>当前最大值res的情况下,我们才看是否满足others <= k,满足才更新。。
这些问题一刷都没想,光觉得卧槽这个做法牛逼啊。
其实二刷仔细想想,才发现,确实牛逼啊
public class Solution {
public int characterReplacement(String s, int k) {
if (s.length() == 0) return 0;
int[] map = new int[26];
int most = ++map[s.charAt(0) - 'A'];
int res = 1;
int left = 0;
for (int right = 1; right < s.length(); right++) {
most = Math.max(most,++map[s.charAt(right) - 'A']);
if (right - left + 1 > most + k) {
map[s.charAt(left++) - 'A']--;
} else {
res = Math.max(res,right - left + 1);
}
}
return res;
}
}
三刷。
脑残啊卧槽,又忘了怎么做了。
windowSize - numOfMajorityElement <= K
主要就是这行,满足的时候更新windowSize,
不满足的时候减少windowSize,减少之后numOfMajorityElement也会变,但是不会变大。
public class Solution {
public int characterReplacement(String s, int k) {
if (s.length() == 0) return 0;
int res = 0;
int l = 0;
int[] letters = new int[26];
int maj = 0;
for (int r = 0; r < s.length(); r++) {
char c = s.charAt(r);
maj = Math.max(maj, ++ letters[c -'A']);
int winSize = r - l + 1;
if (winSize - maj <= k) {
res = Math.max(winSize, res);
} else {
letters[s.charAt(l++) - 'A'] --;
}
}
return res;
}
}
424. Longest Repeating Character Replacement的更多相关文章
- LeetCode 424. Longest Repeating Character Replacement
原题链接在这里:https://leetcode.com/problems/longest-repeating-character-replacement/description/ 题目: Given ...
- 【leetcode】424. Longest Repeating Character Replacement
题目如下: Given a string that consists of only uppercase English letters, you can replace any letter in ...
- 424 Longest Repeating Character Replacement 替换后的最长重复字符
给你一个仅由大写英文字母组成的字符串,你可以将任意位置上的字符替换成另外的字符,总共可最多替换 k 次.在执行上述操作后,找到包含重复字母的最长子串的长度.注意:字符串长度 和 k 不会超过 104. ...
- 【LeetCode】424. 替换后的最长重复字符 Longest Repeating Character Replacement(Python)
作者: 负雪明烛 id: fuxuemingzhu 公众号:每日算法题 本文关键词:LeetCode,力扣,算法,算法题,字符串,双指针,刷题群 目录 题目描述 题目大意 解题方法 双指针 代码 欢迎 ...
- Leetcode: Longest Repeating Character Replacement && G 面经
Given a string that consists of only uppercase English letters, you can replace any letter in the st ...
- [Swift]LeetCode424. 替换后的最长重复字符 | Longest Repeating Character Replacement
Given a string that consists of only uppercase English letters, you can replace any letter in the st ...
- G 面经 && Leetcode: Longest Repeating Character Replacement
Given a string that consists of only uppercase English letters, you can replace any letter in the st ...
- LeetCode——Longest Repeating Character Replacement
1. Question Given a string that consists of only uppercase English letters, you can replace any lett ...
- leetcode424 Longest Repeating Character Replacement
""" Given a string s that consists of only uppercase English letters, you can perform ...
随机推荐
- 拦截器getmodel方法什么时候被调用(没搞懂有什么鸟用,自己搭的项目中用到了这个)
拦截器是Struts2最强大的特性之一,它是一种可以让用户在Action执行之前和Result执行之后进行一些功能处理的机制.Struts2 的预定义拦截器 modelDriven 如果action实 ...
- C蛮的全栈之路-序章 技术栈选择与全栈工程师
目录 C蛮的全栈之路-序章 技术栈选择与全栈工程师C蛮的全栈之路-node篇(一) 环境布置C蛮的全栈之路-node篇(二) 实战一:自动发博客 博主背景 985院校毕业,至今十年C++开发工作经验, ...
- 显示scrollbar
修改CSS overflow的值 overflow: 参考MDN 例子: overflow: auto or scroll
- SpringMVC4+thymeleaf3的一个简单实例(篇四:form表单数据验证)
关于表单数据验证有很多中方法,这里我仅介绍JSR303注解验证.JSR303仅仅是一个规范,这里我们要用到它的一个实现:hibernate-validator. 注意在spring的配置文件sprin ...
- 子树大小平衡树(Size Balanced Tree,SBT)操作模板及杂谈
基础知识(包括但不限于:二叉查找树是啥,SBT又是啥反正又不能吃,平衡树怎么旋转,等等)在这里就不(lan)予(de)赘(duo)述(xie)了. 先贴代码(数组模拟): int seed; int ...
- SGU 131.Hardwood floor
时间限制:0.25s 空间限制:4M 题意: 给出 n*m (1≤n.m≤9)的方格棋盘,用 1*2 的矩形的骨牌和 L 形的(2*2 的 去掉一个角)骨牌不重叠地覆盖,求覆盖满的方案数. Solut ...
- nginx插件ngx_lua
ngx_lua是淘宝的维护的产品,真心不错.配置文件包含可以做很多事情的lua脚本. 公司有个产品对注册的广告盒子进行反向代理,这样可以在盒子上做很多事情:和服务器通信,远程控制盒子等等.nginx反 ...
- contos 安装jdk1.8
JDK安装配置 查看centos系统32位还是64位, 使用命令uname -a;x86是386,586系列的统称,主要是指指令集合.X64才是cpu对64位计算的支持版本. 1. 下载jdk,本例使 ...
- HTML5中的Range对象的研究(转载)
一:Range对象的概念 Range对象代表页面上的一段连续区域,通过Range对象,可以获取或修改页面上的任何区域,可以通过如下创建一个空的Range对象,如下: var range = docu ...
- dedecms 常用标签调用
/*------------------单个ip调用-------------------*/ {dede:type typeid="12"} <a title=" ...