leetcode hot100 438. 找到字符串中所有字母异位词 滑动窗口 medium

直觉:
滑动窗口 + 排序法

窗口的大小会始终保持为 p 的长度,保证每次比较的都是相同长度的子串

窗口右移

排序比较

python 复制代码
class Solution:
    def findAnagrams(self, s: str, p: str) -> List[int]:

        if len(s) < len(p):
            return []

        if not s or not p:
            return []

        res = []
        p_sorted = sorted(p)  # 排序 p 以便与窗口进行比较

        # 使用切片获取初始窗口
        for i in range(len(p) - 1, len(s)):
            window = s[i - len(p) + 1: i + 1]  # 正确获取窗口
            if sorted(window) == p_sorted:
                res.append(i - len(p) + 1)  # 存储当前窗口的起始索引

        return res

排序的时间复杂度是 O(k log k),其中 k 是 p 的长度。

每次滑动窗口时需要对窗口进行排序

时间复杂度 :O(n * k log k),其中 n 是字符串 s 的长度,k 是字符串 p 的长度
空间复杂度 :O(n + k),其中 n 是字符串 s 的长度,k 是字符串 p 的长度。

如果字符串 p 较大(即 k 较大),排序操作的代价会比较高

滑动窗口 + 频率计数法

python 复制代码
class Solution:
    def findAnagrams(self, s: str, p: str) -> List[int]:

        cnt_p = Counter(p)  # 统计 p 中每个字符的频率  "abc" -> Counter({'a': 1, 'b': 1, 'c': 1})
        cnt_window = Counter()  # 统计 s 中当前窗口的字符频率
        plen = len(p)

        res = []
        left = 0

        for right in range(len(s)):

            cnt_window[s[right]] += 1  # 右端点字符进入窗口,增加该字符的计数

            winlen = right - left +1
            if winlen < plen:
                continue   # 继续for循环移动右指针

            # 达到p长度
            else:
                if cnt_p == cnt_window:   # # 如果窗口的字符频率和 p 的字符频率一样,说明是异位词
                    res.append(left)  # 记录左端点的索引

                    cnt_window[s[left]] -= 1   # 左端点移出windows
                    left += 1   # 左指针前进
                else :
                    cnt_window[s[left]] -= 1   # 左端点移出windows
                    left += 1   # 左指针前进

        return res

总时间复杂度 :O(n×k)

其中 n 是字符串 s 的长度,k 是字符串 p 的长度。
空间复杂度: O(k+n)

相关推荐
似水明俊德5 小时前
02-C#.Net-反射-面试题
开发语言·面试·职场和发展·c#·.net
腾阳7 小时前
99%的人忽视了这一点:活着本身就是人生的意义,别让抑郁和内耗成为你的枷锁!
经验分享·程序人生·职场和发展·跳槽·学习方法·媒体
不吃西红柿的857 小时前
[职场] 内容运营求职简历范文 #笔记#职场发展
笔记·职场和发展·内容运营
liyang_8307 小时前
邦芒秘诀:职场高手都具备的三个特征
职场和发展
普通网友7 小时前
十大秘闻:揭秘霍兰德职业兴趣理论的未知面!
职场和发展·求职招聘·职场发展·单一职责原则
爱我所爱flash7 小时前
职场上,如果不想被淘汰,谨记这3条生存法则,早知早获益
职场和发展
程序员雨果7 小时前
软件测试工程师:面试题与经验分享
软件测试·面试·职场和发展
普通网友7 小时前
[职场] 运营支撑是什么意思 #其他#学习方法#职场发展
职场和发展·学习方法
Yvonne爱编码7 小时前
2026年计算机专业求职指南:从简历优化到技术面试通关【科普类】
面试·职场和发展
测试界的飘柔7 小时前
月薪 20k 的性能测试面试题大曝光,让你如何迅速拿下 offer!
自动化测试·软件测试·功能测试·面试·职场和发展·职场经验·找工作