给定两个字符串 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