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

复制代码
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

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

相关推荐
m0_463672201 分钟前
HTML函数工具是否支持雷蛇等游戏外设_RGB同步汇总【汇总】
jvm·数据库·python
谙弆悕博士2 分钟前
【附C源码】二叉搜索树的C语言实现
c语言·开发语言·数据结构·算法·二叉树·项目实战·数据结构与算法
C+++Python4 分钟前
C++ 泛型编程 极简示例代码
开发语言·c++
zkkkkkkkkkkkkk7 分钟前
python使用celery实现异步任务
redis·python·rabbitmq·rocketmq
Rust研习社11 分钟前
Ubuntu 全面拥抱 Rust 后,我意识到 Rust 社区要变了
linux·服务器·开发语言·后端·ubuntu·rust
宵时待雨15 分钟前
回溯算法专题2:二叉树中的深搜
开发语言·数据结构·c++·笔记·算法·深度优先
jiayong2319 分钟前
第 43 课:任务详情抽屉里的批量处理闭环与删除联动
java·开发语言·前端
likerhood20 分钟前
Java 访问修饰符:public、protected、private讲解
java·开发语言·javascript
iAm_Ike22 分钟前
如何用 IndexedDB 存储从 API 获取的超大列表并实现二级索引
jvm·数据库·python
Land032926 分钟前
指纹浏览器自动化集成方案|多浏览器RPA适配实战记录
运维·人工智能·爬虫·python·selenium·自动化·rpa