力扣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

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

相关推荐
广州灵眸科技有限公司16 分钟前
瑞芯微(EASY EAI)RV1126B 模型部署API说明
linux·开发语言·网络·人工智能·深度学习·算法·yolo
東隅已逝,桑榆非晚17 分钟前
深⼊理解指针(5)
c语言·笔记·算法
lwf00616421 分钟前
顺序模型学习日记
算法
_日拱一卒25 分钟前
LeetCode:199二叉树的右视图
算法·leetcode·职场和发展
The Chosen One98532 分钟前
分享对dp题目的理解-不断更新ing
笔记·算法·深度优先·动态规划·dp
有时间要学习36 分钟前
【无标题】
算法
re林檎37 分钟前
算法札记——5.15
算法
鱼子星_41 分钟前
【数据结构与算法】OJ题目详解(一)-单链表:从易到难的面试OJ题目
c语言·数据结构·算法·链表·面试·职场和发展
人道领域42 分钟前
【LeetCode刷题日记】递归与回溯实战 257.二叉树的所有路径——一篇文章彻底搞懂回溯
开发语言·python·算法·leetcode
ulias21244 分钟前
leetcode热题 - 7
数据结构·算法·leetcode