
395 至少有K个重复字符的最长子串(递归)
发布日期:2021-05-07 21:56:22
浏览次数:12
分类:技术文章
本文共 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)
发表评论
最新留言
能坚持,总会有不一样的收获!
[***.219.124.196]2025年03月21日 14时01分53秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
Spring源码:initApplicationEventMulticaster源码解析
2019-03-04
AcWing 786: 第k个数
2019-03-04
AcWing 828. 模拟栈
2019-03-04
添加Selinux权限
2019-03-04
ifconfig网络配置信息解析
2019-03-04
(2019.9.10测试可用)如何在Windows的cmd中使用ls命令
2019-03-04
债券中的久期是什么意思
2019-03-04
(20200328已解决)从docker容器内复制文件到宿主机
2019-03-04
理解Docker ulimit参数
2019-03-04
理解Python系统下的时间格式
2019-03-04
Python语言'类'概念再理解
2019-03-04
OpenAI Gym简介及初级实例
2019-03-04
Ubuntu 18.04 zip压缩文件及其文件 夹中的所以 内容
2019-03-04
int 转 CString
2019-03-04
Edit编辑框自动换行与长度
2019-03-04
低通滤波器的设计
2019-03-04
窄带随机过程的产生
2019-03-04
随机四则运算
2019-03-04
Java面向对象
2019-03-04