滑动窗口:寻找字符串中的字母异位词

复制代码
class Solution:
    def findAnagrams(self,s:str,p:str)->List[int]:
        ht={}
        window={}
        m=len(s)
        n=len(p)
        res=[]
        if m<n:
            return res
        left=0
        valid=0
        for a in p:  #记录p字符串出现的频率
            ht[a]=ht.get(a,0)+1

        for right in range(m): #开始遍历s字符串
            c=s[right]
            if c in ht: #右边界移动
                window[c]=window.get(c,0)+1
                if window[c]==ht[c]:
                    valid+=1
            if right-left+1>n: #移动左边界,窗口大了,需要缩小,但是缩小前,需要先检查
                d=s[left]
                if d in ht: #需要先判断当前字符在不在ht里面,在的话才需要对比
                    if window[d]==ht[d]:
                        valid-=1
                    window[d]-=1
                left+=1
            if valid==len(ht):
                res.append(left)
        return res

思路:通过记录每个字符出现的次数来进行对比。滑动窗口:左指针往右收缩,右指针往右扩展,时刻检查窗口大小,一旦超出窗口大小,就需要缩小窗口,缩小窗口前,需要先检查左指针指向的字符是否在目标哈希表内,如果在的话,继续对比该字符在窗口的数量与在目标哈希表的数量是否一致,如果一致,匹配度需要减一(因为等会就要在窗口删掉该字符)。匹配度减一后,该字符在窗口的数量减一,之后再移动左指针。

相关推荐
xiaoye37082 小时前
Java 自动装箱 / 拆箱 原理详解
java·开发语言
ZTLJQ4 小时前
数据的基石:Python中关系型数据库完全解析
开发语言·数据库·python
夏霞4 小时前
c# signlar 客户端传递参数给服务端配置方法
开发语言·c#
迷藏4944 小时前
**发散创新:基于 Rust的开源权限管理系统设计与实战**在现代软件架构中,**权限控制**早已不
java·开发语言·rust·开源
FreakStudio4 小时前
lvgl-micropython、lv_micropython和lv_binding_micropython到底啥关系?一文读懂
python·单片机·嵌入式·面向对象·电子diy
2301_818419015 小时前
C++中的解释器模式变体
开发语言·c++·算法
小江的记录本5 小时前
【Redis】Redis全方位知识体系(附《Redis常用命令速查表(完整版)》)
java·数据库·redis·后端·python·spring·缓存
摇滚侠5 小时前
Java 项目《谷粒商城-1》架构师级Java 项目实战,对标阿里 P6-P7,全网最强,实操版本
java·开发语言
dinl_vin5 小时前
Python 数据分析入门系列(一):从NumPy开始
python·数据分析·numpy
biter down5 小时前
C++11 统一列表初始化+std::initializer_list
开发语言·c++