
395 至少有K个重复字符的最长子串(递归)
发布日期:2021-05-07 21:56:22
浏览次数:18
分类:精选文章
本文共 932 字,大约阅读时间需要 3 分钟。
1. 问题描述:
找到给定字符串(由小写字符组成)中的最长子串 T , 要求 T 中的每一字符出现次数都不少于 k 。输出 T 的长度。
示例 1:
输入:
s = "aaabb", k = 3 输出: 3 最长子串为 "aaa" ,其中 'a' 重复了 3 次。示例 2:
输入:
s = "ababbc", k = 2 输出: 5 最长子串为 "ababb" ,其中 'a' 重复了 2 次, 'b' 重复了 3 次。来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/longest-substring-with-at-least-k-repeating-characters2. 思路分析:
分析题目可以知道当存在某些字符的次数少于k的时候那么T的长度只能够在以这些字符作为分割之后的子串中寻找,一个比较方便的做法是使用递归来解决,我们可以使用set集合得到s中不重复的字符集合,然后遍历这些字符,当发现字符次数少于k的时候那么就以当前的字符作为分隔符求解剩下的字符串是否满足,对于次数不满足的字符都是这样寻找所以可以使用递归解决,我们只要在剩余的子串串中找出满足条件的子串并给求解出最大的长度即可,递归的时候当子串中字符出现的次数大于等于k的时候那么返回当前的字串的长度,当长度小于k直接返回0
3. 代码如下:
class Solution: def longestSubstring(self, s: str, k: int) -> int: if len(s) < k: return 0 # 获取s中字符串中出现的不重复字符 for c in set(s): # 当次数小于k的时候以当前字符作为分隔符求解剩余的字符串是否满足条件并且在满足条件的子串中找到最长的子串 if s.count(c) < k: return max(self.longestSubstring(t, k) for t in s.split(c)) return len(s)
发表评论
最新留言
网站不错 人气很旺了 加油
[***.192.178.218]2025年04月16日 11时25分11秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
【编程】C语言入门:1到 100 的所有整数中出现多少个数字9
2019-03-09
pair的用法
2019-03-09
javaWeb服务详解(含源代码,测试通过,注释) ——Emp的Dao层
2019-03-11
echarts 基本图表开发小结
2019-03-11
TreeSet、TreeMap
2019-03-11
JVM内存模型
2019-03-11
可变长度参数
2019-03-11
GitHub上传时,项目在已有文档时直接push出现错误解决方案
2019-03-11
嵌入式系统试题库(CSU)
2019-03-12
00010.02最基础客户信息管理软件(意义类的小项目,练习基础,不涉及数据库)
2019-03-12
00013.05 字符串比较
2019-03-12
UE4 错误列表 error码(只记录我遇到的情况,持续添加,未完成)
2019-03-13
Android 架构组件 – 让天下没有难做的 App
2019-03-13
能解决数据可视化大屏需求的3款可视化工具
2019-03-13
第01问:MySQL 一次 insert 刷几次盘?
2019-03-13
Android 开发常用的工具类(更新ing)
2019-03-13
Python爬虫训练:爬取酷燃网视频数据
2019-03-14