【LeetCode刷题】找到字符串中所有字母异位词

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

示例 1:

复制代码
输入: s = "cbaebabacd", p = "abc"
输出: [0,6]
解释:
起始索引等于 0 的子串是 "cba", 它是 "abc" 的异位词。
起始索引等于 6 的子串是 "bac", 它是 "abc" 的异位词。

示例 2:

复制代码
输入: s = "abab", p = "ab"
输出: [0,1,2]
解释:
起始索引等于 0 的子串是 "ab", 它是 "ab" 的异位词。
起始索引等于 1 的子串是 "ba", 它是 "ab" 的异位词。
起始索引等于 2 的子串是 "ab", 它是 "ab" 的异位词。

提示:

  • 1 <= s.length, p.length <= 3 *
  • sp 仅包含小写字母

解题思路:

  1. s 的长度小于 p 的长度,直接返回空列表(不可能存在异位词)。
  2. 分别统计 p 的字符频率和 s 中长度为 len(p) 的初始窗口的字符频率。
  3. 滑动窗口遍历 s:每次窗口右移一位,更新窗口的字符频率,并比较当前窗口与 p 的字符频率是否一致。若一致,则记录当前窗口的起始索引。

Python代码:

python 复制代码
from typing import List
import re


class Solution:
    def findAnagrams(self, s: str, p: str) -> List[int]:
        n, m = len(s), len(p)
        if n < m:
            return []

        cnt_p = [0] * 26
        cnt_s = [0] * 26

        for i in range(m):
            cnt_p[ord(p[i]) - ord('a')] += 1
            cnt_s[ord(s[i]) - ord('a')] += 1

        res = []
        if cnt_p == cnt_s:
            res.append(0)

        for i in range(1, n - m + 1):
            cnt_s[ord(s[i - 1]) - ord('a')] -= 1
            cnt_s[ord(s[i + m - 1]) - ord('a')] += 1
            if cnt_p == cnt_s:
                res.append(i)

        return res


if __name__ == "__main__":
    # 处理输入(格式如:s = "cbaebabacd",p = "abc")
    s_input = input().strip()
    p_input = input().strip()

    # 提取字符串内容
    s = re.search(r'"(.*?)"', s_input).group(1)
    p = re.search(r'"(.*?)"', p_input).group(1)

    solution = Solution()
    result = solution.findAnagrams(s, p)
    print(result)

LeetCode提交代码:

python 复制代码
class Solution:
    from typing import List
    def findAnagrams(self, s: str, p: str) -> List[int]:
        n, m = len(s), len(p)
        if n < m:
            return []
        
        # 初始化字符频率数组(仅小写字母,长度为26)
        cnt_p = [0] * 26
        cnt_s = [0] * 26
        
        # 统计p的字符频率和s的初始窗口(前m个字符)的频率
        for i in range(m):
            cnt_p[ord(p[i]) - ord('a')] += 1
            cnt_s[ord(s[i]) - ord('a')] += 1
        
        res = []
        # 检查初始窗口是否为异位词
        if cnt_p == cnt_s:
            res.append(0)
        
        # 滑动窗口遍历剩余部分
        for i in range(1, n - m + 1):
            # 移除窗口左侧的字符
            cnt_s[ord(s[i-1]) - ord('a')] -= 1
            # 加入窗口右侧的新字符
            cnt_s[ord(s[i + m - 1]) - ord('a')] += 1
            # 检查当前窗口是否为异位词
            if cnt_p == cnt_s:
                res.append(i)
        
        return res
        

程序运行结果如下:

总结

本文介绍了在字符串s中查找所有p的异位词子串的算法。异位词指字母相同但顺序不同的字符串。算法采用滑动窗口法,通过维护两个字符频率数组(分别对应p和s的当前窗口)进行比较。具体步骤包括:1)检查s长度不小于p;2)初始化字符频率数组;3)滑动窗口遍历s,更新窗口频率并比较。时间复杂度为O(n),空间复杂度为O(1)。示例输入如s="cbaebabacd",p="abc"时输出0,6,验证了算法的正确性。该解法适用于处理小写字母组成的字符串匹配问题。

相关推荐
hhzz5 小时前
基于监控视频的水位尺自动识别技术方案与实现
python·opencv·yolo·图像识别·cv
yongche_shi5 小时前
ragas官方文档中文版(五十)
开发语言·python·ai·ragas·如何评估和改进 rag 应用
QiLinkOS5 小时前
第三视觉理解徐玉生与他的商业活动(30)
大数据·c++·人工智能·算法·开源协议
疯狂打码的少年5 小时前
【操作系统】页面置换算法(OPT/FIFO/LRU)
算法
小O的算法实验室6 小时前
2026年CIE,优化客货协同运输:综合地铁系统的列车容量动态分配
算法
weixin_408099676 小时前
OCR批量识别图片方案:从手动处理到自动化API系统(Python/Java/PHP实战)
图像处理·python·ocr·文字识别·api调用·批量识别·石榴智能
AI行业学习6 小时前
Notepad++ 官方下载 + 完整安装 + 全套优化配置(2026最新)
开发语言·人工智能·python·前端框架·html·notepad++
Coder_Shenshen7 小时前
西门子S7CommPlus协议鉴权算法原理与流程详解
网络·后端·算法
大圣编程7 小时前
Python中continue语句的用法是什么?
开发语言·前端·python
硕风和炜7 小时前
【LeetCode: 2492. 两个城市间路径的最小分数 + DFS】
java·算法·leetcode·深度优先·dfs·bfs·并查集