力扣438 找到字符串中所有字母异位词 Java版本

文章目录


题目描述

给定两个字符串 s 和 p,找到 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 * 104

s 和 p 仅包含小写字母

代码

java 复制代码
class Solution {
    public List<Integer> findAnagrams(String s, String p) {
        List<Integer> res = new ArrayList<>();
        //将p排序之后方便对比
        char[] chars = p.toCharArray();
        Arrays.sort(chars);
        String newP = new String(chars);
        for (int i = 0; i <= s.length() - p.length(); i++) {
            String substring = s.substring(i, i + p.length());
            char[] chars1 = substring.toCharArray();
            Arrays.sort(chars1);
            String newSubstring = new String(chars1);
            if (newP.equals(newSubstring)){
                res.add(i);
            }
        }
        return res;
    }
}
相关推荐
null or notnull2 小时前
java服务器空间不够时:将多个服务器的文件存放至同一个服务器上(使用映射器的办法)
java·运维·服务器·java-ee
代码栈上的思考2 小时前
JVM中内存管理的策略
java·jvm
Freshman小白2 小时前
python算法打包为docker镜像(边缘端api服务)
python·算法·docker
YoungP2 小时前
【Effective Java 条目二】-- 当构造器参数较多时考虑使用生成器
java
mit6.8242 小时前
[VT-Refine] Simulation | Fine-Tuning | docker/run.sh
算法
朴shu2 小时前
Delta数据结构:深入剖析高效数据同步的奥秘
javascript·算法·架构
野生技术架构师2 小时前
牛客网Java 高频面试题总结(2025最新版)
java·开发语言·面试
纪莫3 小时前
技术面:SpringBoot(springboot的类加载和传统的双亲委派有什么区别、如何按顺序实例化Bean)
java·spring·java面试⑧股
mit6.8243 小时前
博弈dp|凸包|math分类
算法
kyle~3 小时前
CPU调度---协程
java·linux·服务器·数据库·c++20