leetcode hot100【LeetCode 438. 找到字符串中所有字母的异位词】java实现

LeetCode 438. 找到字符串中所有字母的异位词

题目描述

给定两个字符串 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 * 10^4
  • sp 仅包含小写字母

Java 实现代码

java 复制代码
class Solution {
    public List<Integer> findAnagrams(String s, String p) {
        int sLength = s.length();
        int pLength = p.length();
        if (sLength < pLength) {
            return new ArrayList<>();
        }
        int[] sArr = new int[26];
        int[] pArr = new int[26];
        List<Integer> data = new ArrayList<>();
        for (int i = 0; i < pLength; i++) {
            sArr[s.charAt(i) - 'a']++;
            pArr[p.charAt(i) - 'a']++;
        }
        for (int i = pLength; i < sLength; i++) {
            if (Arrays.equals(sArr, pArr)) {
                data.add(i - pLength);
            }
            int left = i - pLength;
            int right = i;
            sArr[s.charAt(left) - 'a']--;
            sArr[s.charAt(right) - 'a']++;
        }
        if (Arrays.equals(sArr, pArr)) {
            data.add(sLength - pLength);
        }
        return data;
    }
}

解题思路

  1. 初始化 :创建两个长度为 26 的数组 sArrpArr,分别用于存储字符串 sp 中每个字符的出现次数。
  2. 填充 pArr :遍历字符串 p,统计每个字符的出现次数。
  3. 滑动窗口 :使用两个指针 leftright 表示窗口的边界,right 指针向右移动扩展窗口。
  4. 更新 sArr :当 right 指针移动时,将新进入窗口的字符的计数加一。
  5. 检查异位词 :如果当前窗口的字符计数与 p 相同,则说明找到了一个异位词,记录下 left 指针的索引。
  6. 移动 left 指针 :当窗口大小超过 p 的长度时,移动 left 指针,减少离开窗口的字符的计数。
  7. 返回结果:最终返回所有找到的异位词子串的起始索引。

复杂度分析

  • 时间复杂度 :O(n),其中 n 是字符串 s 的长度。每个字符只被访问两次(一次由 right 指针,一次由 left 指针)。
  • 空间复杂度:O(1),使用固定大小的数组存储字符计数,不依赖于输入大小。
相关推荐
带刺的坐椅4 小时前
超越 SpringBoot 4.0了吗?OpenSolon v3.8, v3.7.4, v3.6.7 发布
java·ai·springboot·web·solon·flow·mcp
就叫飞六吧4 小时前
基于spring web实现简单分片上传demo
java·前端·spring
chao1898444 小时前
基于MATLAB的ADI方法求解偏微分方程详解
开发语言·算法·matlab
apihz4 小时前
免费手机号归属地查询API接口详细教程
android·java·运维·服务器·开发语言
智驱力人工智能4 小时前
超越识别 将光学字符识别(OCR)技术转化为可靠业务能力的交付思维 光学字符识别 金融票据OCR识别系统 物流单据自动识别技术
人工智能·opencv·算法·目标检测·ocr·边缘计算
程序员小假4 小时前
学院本大二混子终于找到实习了...
java·后端
回吐泡泡oO4 小时前
找不到rar.RarArchiveInputStream?JAVA解压RAR5的方案。
java·开发语言
jiayong234 小时前
AI应用领域编程语言选择指南:Java vs Python vs Go
java·人工智能·python
bjzhang754 小时前
IDEA 2025.3重磅发布,Ultimate 终极版和 Community社区版二合一,免费版可商用
java·idea
程序猿零零漆4 小时前
Spring之旅 - 记录学习 Spring 框架的过程和经验(三)Bean的依赖注入配置、Spring的其它配置标签
java·学习·spring