力扣76最小覆盖子串

给定两个字符串 s 和 t,长度分别是 m 和 n,返回 s 中的 最短窗口 子串,使得该子串包含 t 中的每一个字符(包括重复字符)。如果没有这样的子串,返回空字符串 ""。

测试用例保证答案唯一。

python 复制代码
class Solution(object):
    def minWindow(self, s, t):
        from collections import defaultdict
        ht = defaultdict(int)
        hs = defaultdict(int)
        for i in range(len(t)):
            ht[t[i]]+=1
        start=0
        match=0
        min_start=0
        min_end=len(s)-1
        found=False
        for i,c in enumerate(s):
            if c in ht:
                hs[c]+=1
                if hs[c]==ht[c]:
                    match+=1
            while match==len(ht):
                found=True
                end=i
                if end-start<min_end-min_start:
                    min_end=end
                    min_start=start
                if s[start] in ht:
                    hs[s[start]]-=1
                    if hs[s[start]]<ht[s[start]]:
                        match-=1
                start += 1
        if found==True:
            answer=s[min_start:min_end+1]
        else:
            answer=""
        return answer

先创建两个默认值为 int(即 0)的字典,后面直接叫做字典。ht字典用来保存t字符串中字符的个数;

hs字典用来保存滑动窗口中字符的个数

主要是讲循环:

右指针不断向右移,直到右移到hs字典满足ht字典。

当匹配上的时候,保存一下这段字符,左指针开始右移。

当左指针指向的字符不在t字符串里时,左指针直接右移,但若左指针指向的字符在t字符串里,就需要将hs字典的该字符个数减一,还需要判断是否还满足ht字典。

当右移之后,满足不了ht字典之后,停止左指针右移,继续右指针右移。

推荐一个我看的教学视频https://www.bilibili.com/video/BV1Zd4y117AT/?vd_source=2613f45f05cdff9eb69129d6b00e37a2

相关推荐
RH2312111 小时前
2026.5.24 数据结构 KMP算法实现
数据结构·算法
江屿风1 小时前
C++图论基础单源最短路-常规版dijkstra算法/堆优化版dijkstra算法/bellman-ford 算法/spfa 算法流食般投喂
开发语言·c++·笔记·算法·图论
浮芷.1 小时前
鸿蒙 6.1 新特性-60fps流畅人物跳跃功能算法深度解析-鸿蒙PC端正弦值计算法
算法·华为·harmonyos·鸿蒙·鸿蒙系统
AI科技星2 小时前
数术工坊·第八卷 大道归一录・番外・下篇 零界封神・万法归元终章
网络·人工智能·算法·几何学·拓扑学
想吃火锅10052 小时前
【leetcode】20.有效的括号js
linux·javascript·leetcode
Misnearch2 小时前
Leetcode热题100
算法·leetcode·职场和发展
我是一颗柠檬2 小时前
【Java项目技术亮点】滑动窗口限流算法
java·开发语言·算法
无限码力2 小时前
华为非AI方向笔试真题 - 楼内救人
算法·华为·华为非ai方向笔试真题·华为笔试真题·华为算法题
一切皆是因缘际会2 小时前
隐层表征解构:LLM感知式幻觉稀疏成因
算法·数学建模·ai·架构