至少有K个重复字符的最长子串

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

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

示例 1:

复制代码
输入:s = "aaabb", k = 3
输出:3
解释:最长子串为 "aaa" ,其中 'a' 重复了 3 次。

示例 2:

复制代码
输入:s = "ababbc", k = 2
输出:5
解释:最长子串为 "ababb" ,其中 'a' 重复了 2 次, 'b' 重复了 3 次。

思路:滑动窗口,没有条件滑就创造条件滑。规定 t 为滑动窗口内最大的字母种类(当取所有可能的 t 时,也就相当于全集了,等于没规定这个条件)。虽然最大种类数为 t 时,t-1可能也会被考虑一些次,但是一定会考虑到长度 仅为 t 的所有情况。而最后的res 一定是某个数目的 字母种类 ,所以一定可以考虑到。

设置 existNum、reachNum 两个变量,一个是存在字母种类数量,一个数到达k数目要求的字母种类数

python 复制代码
from collections import defaultdict


class Solution:
    def longestSubstring(self, s: str, k: int) -> int:
        charSet = set(s)
        res = 0
        # 滑动窗口内最大的字母种类
        for t in range(1,len(charSet)+1):
            exist=defaultdict(int)
            existNum=0
            reachNum=0
            l,r=0,0
            while r<len(s):
                exist[s[r]] += 1
                # 存在
                if exist[s[r]] == 1:
                    existNum += 1
                # 满足
                if exist[s[r]] == k:
                    reachNum += 1

                while l<=r and existNum>t:
                    exist[s[l]]-=1
                    if exist[s[l]]==0:
                        existNum-=1

                    if exist[s[l]] == k-1:
                        reachNum -= 1
                    l += 1

                if reachNum==existNum:
                    res=max(res,r-l+1)
                r += 1

自己写的一版错误的:

没有最外层的 t ,这样滑 处理不了 "baaabcb" 这种情况。

python 复制代码
from collections import defaultdict


class Solution:
    def longestSubstring(self, s: str, k: int) -> int:
        res = 0
        characterDict=defaultdict(int)
        for c in s:
            characterDict[c]+=1
        exist=defaultdict(int)
        existNum=0
        reachNum=0
        l,r=0,0
        while r<=len(s):
            if r==len(s) or exist[s[r]]+characterDict[s[r]]<k:
                while l<r and reachNum<existNum:
                    exist[s[l]]-=1
                    if exist[s[l]]==0:
                        existNum-=1

                    if exist[s[l]] == k-1:
                        reachNum -= 1
                    l += 1

                res=max(res,r-l)
                l=r=r+1

            else:
                exist[s[r]] += 1
                #存在
                if exist[s[r]]==1:
                    existNum+=1

                #满足
                if exist[s[r]]==k:
                    reachNum+=1
                r+=1
        return res
print(Solution().longestSubstring("baaabcb", 3))
相关推荐
wyw00001 小时前
FFmpeg实现带颜色MXF转mp4
python·ffmpeg
knight_9___1 小时前
大模型project面试6
人工智能·python·agent·rag·mcp
想带你从多云到转晴1 小时前
优选算法---双指针
java·算法
2401_867623981 小时前
SQL如何提取分组中的第一条记录_使用ROW_NUMBER定位数据
jvm·数据库·python
三品吉他手会点灯2 小时前
C语言学习笔记 - 32.嵌入式C语言学习阶段对初学编程者的建议
c语言·开发语言·笔记·学习
l1t2 小时前
DeepSeek总结的一种带宽高效的压缩基数排序FractalSortCPU
开发语言·python
沐知全栈开发2 小时前
jEasyUI 树形网格动态加载详解
开发语言
Java源头2 小时前
PHP 身份证二要素检测
开发语言·php
折哥的程序人生 · 物流技术专研2 小时前
《Java 100 天进阶之路》第21篇:Java Object类
java·开发语言·后端·面试·哈希算法