力扣483找到字符串中所有字母异位词

给定两个字符串 s 和 p,找到 s 中所有 p 的 异位词 的子串,返回这些子串的起始索引。不考虑答案输出的顺序。

python 复制代码
class Solution(object):
    def findAnagrams(self, s, p):
        #存放数组
        res=[]
        len_s=len(s)#s字符串长度
        len_p=len(p)#p字符串长度
        if len_s<len_p:
            return []
        count_p=[0]*26 
        count_s=[0]*26
        for i in range(len_p):
            count_p[ord(p[i])-ord('a')]+=1
            count_s[ord(s[i])-ord('a')]+=1
        #第一个滑动窗口匹配
        if count_s == count_p:
            res.append(0)
        #移动滑动窗口,判断是否匹配成功
        for i in range(1,len_s-len_p+1):
            #移除左边字符
            left_char=s[i-1]
            count_s[ord(left_char)-ord('a')]-=1
            #添加右边字符
            right_char=s[i+len_p-1]
            count_s[ord(right_char)-ord('a')]+=1
            if count_p==count_s:
                res.append(i)
        return res

需要采用滑动串口,左边移除一个字符,右边添加一个字符,又因为他不要求字符顺序,所以可以采用每个字符的出现次数来判断是否匹配上。

相关推荐
小O的算法实验室2 小时前
2022年IEEE TETCI,基于矩阵的进化计算,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
欧米欧2 小时前
STRING的底层实现
前端·c++·算法
smj2302_796826522 小时前
解决leetcode第3906题统计网格路径中好整数的数目
python·算法·leetcode
KobeSacre2 小时前
leetcode 树
算法·leetcode·职场和发展
6Hzlia2 小时前
【Hot 100 刷题计划】 LeetCode 104. 二叉树的最大深度 | C++ 自底向上递归最优解
算法
Robot_Nav2 小时前
Kinodynamic Lazy ThetaStar:面向实时机器人导航的两阶段运动学路径规划算法
算法·机器人·lazy theta
热心网友俣先生2 小时前
2026华中杯A题超详细解题思路+第一篇论文分享
人工智能·算法·机器学习
全栈开发圈3 小时前
新书速览|机器人系统开发与优化:算法、感知与控制策略
算法·目标跟踪·机器人
大大杰哥3 小时前
leetcode hot100(1) 哈希
leetcode