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

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

相关推荐
Billlly16 小时前
莫比乌斯反演学习笔记
算法
stolentime16 小时前
CF2066D1 Club of Young Aircraft Builders (easy version)题解
c++·算法·动态规划·组合数学
Dillon Dong17 小时前
【风电控制】高低穿现场失败的原因分析——算法简单但工程复杂
算法·变流器·风电控制·dfig
小欣加油17 小时前
leetcode41 缺失的第一个正数
数据结构·c++·算法·leetcode
I Promise3417 小时前
智驾APA_HPA可行驶区域检测算法工程师面试问题整理可参考
算法·面试·职场和发展
智者知已应修善业17 小时前
【51单片机按键控制1分钟正计时倒计时暂停复位】2024-1-2
c++·经验分享·笔记·算法·51单片机
weixin_4684668517 小时前
UNet 模型结构从零搭建与实战解析
人工智能·深度学习·算法·机器学习·ai·unet
Useasy_JIJIANYUN17 小时前
合作快讯:极简云呼叫中心(Useasy)正式上架Zoho全球应用市场!
算法
isyoungboy18 小时前
Delaunay 拓扑图割法一种特征抽稀算法
算法
Shan120518 小时前
算法案例精讲:连接所有点的最小费用
算法