至少有k个重复字符的最长子串(LeetCode)

题目

给你一个字符串 s 和一个整数 k ,请你找出 s 中的最长子串, 要求该子串中的每一字符出现次数都不少于 k 。返回这一子串的长度。

如果不存在这样的子字符串,则返回 0。

解题

python 复制代码
def longestSubstring(s, k):
    # 如果字符串长度为0或者字符串长度小于k,返回0
    if len(s) == 0 or len(s) < k:
        return 0

    # 如果字符串中所有字符的出现次数都大于等于k,返回字符串的长度
    if all(s.count(char) >= k for char in set(s)):
        return len(s)

    # 否则进行分治
    for char in set(s):
        if s.count(char) < k:
            # 对字符串进行分割
            return max(longestSubstring(sub, k) for sub in s.split(char))

    return len(s)


# 示例
s = "aaabb"
k = 3
print(longestSubstring(s, k))  # 输出: 3, 因为最长子串是 "aaa"

s = "ababbc"
k = 2
print(longestSubstring(s, k))  # 输出: 5, 因为最长子串是 "ababb"
相关推荐
小月球~6 小时前
天梯赛 · 并查集
数据结构·算法
仍然.7 小时前
算法题目---模拟
java·javascript·算法
6Hzlia8 小时前
【Hot 100 刷题计划】 LeetCode 118. 杨辉三角 | C++ 动态规划题解
c++·leetcode·动态规划
潇冉沐晴9 小时前
DP——背包DP
算法·背包dp
GIOTTO情9 小时前
2026 世界互联网大会亚太峰会|AI 时代媒介投放的技术实战与算法优化
人工智能·算法
逆境不可逃9 小时前
LeetCode 热题 100 之 543. 二叉树的直径 102. 二叉树的层序遍历 108. 将有序数组转换为二叉搜索树 98. 验证二叉搜索树
算法·leetcode·职场和发展
计算机安禾9 小时前
【数据结构与算法】第19篇:树与二叉树的基础概念
c语言·开发语言·数据结构·c++·算法·visual studio code·visual studio
副露のmagic10 小时前
哈希章节 leetcode 思路&实现
算法·leetcode·哈希算法
副露のmagic10 小时前
字符串章节 leetcode 思路&实现
windows·python·leetcode
csuzhucong10 小时前
puzzle(1037)黑白、黑白棋局
算法