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

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

相关推荐
To_OC13 小时前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
金銀銅鐵17 小时前
[Python] 扩展欧几里得算法
python·数学·算法
To_OC19 小时前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
To_OC1 天前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
05Kevin2 天前
lk每日冒险题--数据结构6.27
算法
To_OC2 天前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安3 天前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法
七牛开发者3 天前
MCP 到底是什么?为什么 Agent 都想接上它
算法·aigc·agent