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),使用固定大小的数组存储字符计数,不依赖于输入大小。
相关推荐
i220818 Faiz Ul15 分钟前
动漫商城|基于springboot + vue动漫商城系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·动漫商城系统
海兰30 分钟前
【实战】MCP 服务在 Nacos 中注册状态分析与优化
android·java·github·银行系统·银行ai
xiaoye-duck1 小时前
《算法题讲解指南:递归,搜索与回溯算法--综合练习》--14.找出所有子集的异或总和再求和,15.全排列Ⅱ,16.电话号码的字母组合,17.括号生成
c++·算法·深度优先·回溯
OOJO1 小时前
c++---vector介绍
c语言·开发语言·数据结构·c++·算法·vim·visual studio
汀、人工智能1 小时前
05 - 函数基础
数据结构·算法·数据库架构·05 - 函数基础
Makoto_Kimur1 小时前
Java 打印模板大全
java·开发语言·排序算法
程序员榴莲1 小时前
Java(十)super关键字
java·开发语言
HAPPY酷1 小时前
Python高级架构师之路——从原理到实战
java·python·算法
枫叶林FYL2 小时前
第9章 因果推理与物理理解
人工智能·算法·机器学习
ybwycx2 小时前
SpringBoot下获取resources目录下文件的常用方法
java·spring boot·后端