力扣题库第9题:找到字符串中所有的异位词

题目:

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

异位词 指由相同字母重排列形成的字符串(包括相同的字符串)。

示例 :

输入: s = "cbaebabacd", p = "abc"

输出: [0,6]

解释:

起始索引等于 0 的子串是 "cba", 它是 "abc" 的异位词。

答案:
复制代码
# coding:utf-8
# 时间:2024/3/14 20:19
# Pythonit教程网(blog.pythonit.cn)
# Python全栈视频课件获取:www.dqu.cc
# 加速高防cdn:woaiyundun.cn
from collections import Counter


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

        # 初始化 p 的字符计数
    p_counts = Counter(p)
    # 初始化滑动窗口的字符计数
    window_counts = Counter()
    # 初始化结果列表
    result = []

    # 遍历 s,维护一个长度为 m 的滑动窗口
    left = 0
    for right in range(n):
        # 窗口向右滑动,添加新的字符到窗口
        window_counts[s[right]] += 1

        # 当窗口大小达到 m,开始检查窗口的字符计数
        if right >= m - 1:
            # 如果窗口最左边的字符在 p 中出现,并且出现次数大于 0,则减少其计数
            if s[left] in p_counts and window_counts[s[left]] > p_counts[s[left]]:
                window_counts[s[left]] -= 1
                # 移动窗口左边界
            left += 1

            # 检查窗口的字符计数是否与 p 的字符计数匹配
            if window_counts == p_counts:
                result.append(left)

                # 如果窗口最左边的字符在 p 中出现,并且出现次数为 0,则需要重新计数
            if s[left] in p_counts and window_counts[s[left]] == p_counts[s[left]]:
                window_counts[s[left]] -= 1

    return result


# 示例
s = "cbaebabacd"
p = "abc"
print(findAnagrams(s, p))  # 输出: [0, 6]
相关推荐
计算机毕设匠心工作室14 分钟前
【python大数据毕设实战】强迫症特征与影响因素数据分析系统、Hadoop、计算机毕业设计、包括数据爬取、数据分析、数据可视化、机器学习、实战教学
后端·python·mysql
xl.liu20 分钟前
零售行业仓库商品数据标记
算法·零售
confiself24 分钟前
通义灵码分析ms-swift框架中CHORD算法实现
开发语言·算法·swift
做怪小疯子26 分钟前
LeetCode 热题 100——二叉树——二叉树的层序遍历&将有序数组转换为二叉搜索树
算法·leetcode·职场和发展
CoderYanger38 分钟前
递归、搜索与回溯-记忆化搜索:38.最长递增子序列
java·算法·leetcode·1024程序员节
Trouville012 小时前
Pycharm软件初始化设置,字体和shell路径如何设置到最舒服
ide·python·pycharm
高-老师2 小时前
WRF模式与Python融合技术在多领域中的应用及精美绘图
人工智能·python·wrf模式
小白学大数据2 小时前
基于Splash的搜狗图片动态页面渲染爬取实战指南
开发语言·爬虫·python
xlq223222 小时前
22.多态(下)
开发语言·c++·算法
零日失眠者2 小时前
【文件管理系列】003:重复文件查找工具
后端·python