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

复制代码
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_37761823几秒前
c++文件锁使用方法 c++如何实现多进程文件同步
jvm·数据库·python
gmaajt5 分钟前
mysql多字段搜索如何设计组合索引_mysql索引查询加速
jvm·数据库·python
2301_777599376 分钟前
MySQL如何快速排查慢查询安全隐患_分析slow_query_log进行优化
jvm·数据库·python
m0_747854528 分钟前
如何检测受保护链接(如 Twitter)的可访问性
jvm·数据库·python
baidu_340998829 分钟前
宝塔面板如何设置网站访问密码_配置Nginx认证保护目录
jvm·数据库·python
2301_7775993713 分钟前
Python闭包是什么_深入理解Python闭包原理与变量作用域
jvm·数据库·python
HHHHH1010HHHHH13 分钟前
mysql事务回滚与存储引擎的关系_mysql回滚机制分析
jvm·数据库·python
用户83562907805117 分钟前
Python 操作 PowerPoint:添加与设置文本框完整教程
后端·python
InfinteJustice29 分钟前
SQL如何处理分组后的空值统计_善用COALESCE与聚合函数
jvm·数据库·python
2301_8038756136 分钟前
JavaScript 中按字段对嵌套对象数组进行分组的实用教程
jvm·数据库·python