力扣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

相关推荐
手写码匠3 小时前
手写 LLM 安全护栏:从内容审核到越狱防御的完整实现
人工智能·深度学习·算法·aigc
luj_17683 小时前
草酸与烟酸对消化及糖代谢的影响解析
服务器·c语言·开发语言·经验分享·算法
青风973 小时前
16-ADAPTRACK:基于自适应阈值的多目标跟踪匹配算法
人工智能·算法·目标跟踪
汤姆yu4 小时前
macOS系统下Aider完整安装、配置与实战使用教程
大数据·人工智能·算法·macos·github·copilot
Sam09274 小时前
【AI 算法精讲 14】TF-IDF:词频与逆文档频率
人工智能·python·算法·ai
AI科技星4 小时前
拓扑生命系统确定性理论:基于32维流形的遗传密码起源与衰老动力学( 中英双语顶刊终稿·标准数学符号)
开发语言·网络·人工智能·算法·机器学习·乖乖数学·全域数学
编程圈子4 小时前
电机驱动开发学习18. SVPWM空间矢量调制算法详解与实现
驱动开发·学习·算法
大鱼>5 小时前
机器学习基础:从零理解核心概念与算法分类
算法·机器学习·分类
AI科技星5 小时前
基于32维Cayley_Dickson超复数的全域拓扑统一场论——反重力、真空自持供能、维度瞬移与星际宇宙脑秩序体系
人工智能·学习·算法·机器学习·数据挖掘
aichitang20245 小时前
数论变换(NTT)
c++·算法·fft·ntt