图解leetcode —— 395. 至少有K个重复字符的最长子串
前言:
每道题附带动态示意图,提供java、python两种语言答案,力求提供leetcode最优解。
描述:
找到给定字符串(由小写字符组成)中的最长子串 T , 要求 T 中的每一字符出现次数都不少于 k 。输出 T 的长度。
示例 1:
输入:
s = "aaabb", k = 3
输出:
3
最长子串为 "aaa" ,其中 'a' 重复了 3 次。
示例 2:
输入:
s = "ababbc", k = 2
输出:
5
最长子串为 "ababb" ,其中 'a' 重复了 2 次, 'b' 重复了 3 次。
思路:
这道题可以用滑动窗口+分治的方法进行解答。

java:
class Solution {
/**
* 计算最长重复子串长度.
*
* @param s 字符串
* @param k 重复次数
* @return 长度
*/
public int longestSubstring(String s, int k) {
int len = s.length();
if (len == 0 || k > len) {
return 0;
}
if (k < 2) {
return len;
}
return countHandler(s.toCharArray(), k, 0, len - 1);
}
/**
* 计算最长重复子串长度逻辑处理
*
* @param chars 字符数组
* @param k 重复次数
* @param start 开始位置
* @param end 结束位置
* @return 长度
*/
private int countHandler(char[] chars, int k, int start, int end) {
if (k > end - start + 1) {
return 0;
}
// 计数器,26代表个字母
int[] times = new int[26];
// 统计字符频率
for (int i = start; i <= end; i++) {
++times[chars[i] - 'a'];
}
// 起点、终点夹逼,去掉首位不符合条件的字符串(滑动窗口)
while (k <= end - start + 1 && times[chars[start] - 'a'] < k) {
start++;
}
while (k <= end - start + 1 && times[chars[end] - 'a'] < k) {
end--;
}
if (k > end - start + 1) {
return 0;
}
// 字符串中间存在不符合条件的字符,即以该字符串为界,分割前子串和后字串,进行计算(分治)
for (int i = start; i <= end; i++) {
if (times[chars[i] - 'a'] < k) {
return (Math.max(countHandler(chars, k, start, i - 1), countHandler(chars, k, i + 1, end)));
}
}
return end - start + 1;
}
}
结果:

python3:
class Solution:
def longestSubstring(self, s: str, k: int) -> int:
length = len(s)
if length == 0 or k > length:
return 0
if k < 2:
return length def countHandler(s: str, k: int, start: int, end: int) -> int:
if k > end - start + 1:
return 0
# 初始化数组
times = [0 for i in range(0, 27)]
for i in range(start, end + 1):
times[ord(s[i]) - ord('a')] += 1
# 起点、终点夹逼,去掉首位不符合条件的字符串(滑动窗口)
while end - start + 1 >= k > times[ord(s[start]) - ord('a')]:
start += 1
while end - start + 1 >= k > times[ord(s[end]) - ord('a')]:
end -= 1
if k > end - start + 1:
return 0
# 字符串中间存在不符合条件的字符,即以该字符串为界,分割前子串和后字串,进行计算(分治)
for i in range(start, end):
if times[ord(s[i]) - ord('a')] < k:
return max(countHandler(s, k, start, i - 1), countHandler(s, k, i + 1, end))
return end - start + 1 return countHandler(s, k, 0, length - 1)
结果:

图解leetcode —— 395. 至少有K个重复字符的最长子串的更多相关文章
- Java实现 LeetCode 395 至少有K个重复字符的最长子串
395. 至少有K个重复字符的最长子串 找到给定字符串(由小写字符组成)中的最长子串 T , 要求 T 中的每一字符出现次数都不少于 k .输出 T 的长度. 示例 1: 输入: s = " ...
- leetcode 395 至少有K个重复字符的最长子串
找到给定字符串(由小写字符组成)中的最长子串 T , 要求 T 中的每一字符出现次数都不少于 k .输出 T 的长度. 示例 1: 输入: s = "aaabb", k = 3 输 ...
- 395.至少有 K 个重复字符的最长子串
题目 给你一个字符串 s 和一个整数 k ,请你找出 s 中的最长子串, 要求该子串中的每一字符出现次数都不少于k .返回这一子串的长度. 示例 1: 输入:s = "aaabb" ...
- 395. 至少有K个重复字符的最长子串
Q: A: 分治,对于字符串s的任何一个字符,如果它的频数(在s中出现的次数)小于k,则它一定不会出现在最后的结果里,也就是从它的位置一劈两半,考察左右.对于当前字符串s,我们先建立字典统计其中每种字 ...
- 395 Longest Substring with At Least K Repeating Characters 至少有K个重复字符的最长子串
找到给定字符串(由小写字符组成)中的最长子串 T , 要求 T 中的每一字符出现次数都不少于 k .输出 T 的长度.示例 1:输入:s = "aaabb", k = 3输出:3最 ...
- [Swift]LeetCode395. 至少有K个重复字符的最长子串 | Longest Substring with At Least K Repeating Characters
Find the length of the longest substring T of a given string (consists of lowercase letters only) su ...
- LeetCode 第 3 题:无重复字符的最长子串(滑动窗口)
LeetCode 第 3 题:无重复字符的最长子串 (滑动窗口) 方法:滑动窗口 滑动窗口模板问题:右指针先走,满足了一定条件以后,左指针向前走,直到不满足条件. 特点:左右指针的方向是一致的,并且是 ...
- leetcode刷题笔记-3. 无重复字符的最长子串(java实现)
题目描述 给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb"输出: 3 解释: 因为无重复字符的最长子串是 "ab ...
- LeetCode随缘刷题之无重复字符的最长子串
欢迎评论区交流. package leetcode.day_12_04; /** * 给定一个字符串 s ,请你找出其中不含有重复字符的最长子串的长度. * <p> * 示例1: * &l ...
随机推荐
- MongoDB的基础命令
MongoDB的介绍 MongoDB: 是一个基于bson(二进制json)的NoSQL数据库 MongoDB的三要素: 数据库: 类似于MYSQL的数据库 集合: 类似于MYSQL的表 文档: 类似 ...
- [考试反思]0814NOIP模拟测试21
前两名是外校的240.220.kx和skyh拿到了190的[暴力打满]的好成绩. 我第5是170分,然而160分就是第19了. 在前一晚上刚刚爆炸完毕后,心态格外平稳. 想想前一天晚上的挣扎: 啊啊啊 ...
- Elasticsearch 技术分析(八):剖析 Elasticsearch 的索引原理
前言 创建索引的时候,我们通过Mapping 映射定义好索引的基本结构信息,接下来我们肯定需要往 ES 里面新增业务文档数据了,例如用户,日志等业务数据.新增的业务数据,我们根据 Mapping 来生 ...
- 表格导出到excel的样式消失该如何修改
工作中遇到一需求,要将后台的表格导出到excel后的表格样式该如何修改呢? 其实表格导出首先需要了解两个插件:jquery.table2excel.js和tableExport.js 1.第一步,写一 ...
- 1.基础篇之vue入门
为了建立高效团队,很多公司会采用全栈工程师,虽然利弊兼有,对于成本优先的创业团队,肯定是首选,特别是对.net生态圈,大部分都是小公司,就更加重要了.这里记录的是对vue的学习点滴,希望对你有所助力. ...
- 8.3 NOIP CE反思
lsc考完以后就CE了,然后滚回去吃*去了! 这次考试都比的一批,整个先是打了暴力然后对拍发现桶有可能炸内存,然后就打了一个hash-map然后......T1 T3全使用了它,结果: 没什么可说的了 ...
- python——字符串操作函数
字符串 join() map() split() rsplit() splitlines() partiton() rpartition() upper() lower() swapcase() ca ...
- Ubuntu清空回收站
ubuntu 回收站的具体位置:$HOME/.local/share/Trash/ 执行如下命令清空回收站: sudo rm -fr $HOME/.local/share/Trash/files/ 如 ...
- 在input输入值改变reducer里的值
输入值改变reducer里的值 通过store.dispatch传入reducer中,函数的第二个参数可以接收到 在reducer中 在todolist文件中 然后在把this.state中的值改变
- linux运维与实践
1.容器云计算节点负载值高,通过top可以看到Load Average:70.1 71.3 70.8,虚拟机有8个cpu: cpu使用率高导致(R状态)? 同时在top中观察一段时间,消耗cpu最 ...