当前位置: 首页 > news >正文

力扣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 仅包含小写字母

代码

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;}
}

http://www.mrgr.cn/news/30354.html

相关文章:

  • Git - Think in Git
  • 华为私有接口类型hybrid
  • 深度学习——AE、VAE
  • 探索 Python HTTP 的瑞士军刀:Requests 库
  • 光刻机上下游产业链(方便选股)
  • 湾区聚力 开源启智 | 2024 CCF中国开源大会暨第五届OpenI/O启智开发者大会闪耀深圳
  • 设计模式之外观设计模式
  • 教师专属:高效查询学生考试成绩系统 - 立即体验吧
  • C++:动态内存分配(new、delete 相比 malloc、free的优势)与运算符重载
  • 完美解决 Async/await 不按预期工作 的正确解决方法,亲测有效!!!
  • python+flask+mongodb+vue撸一个实时监控linux服务资源的网站
  • 从 InnoDB 到 Memory:MySQL 存储引擎的多样性
  • 更换UFS绑定固件与“工程固件”的区别 小米10s机型更换cpu绑定包对比 写入以及修复基带
  • 无人机 PX4 飞控 | EKF 使用传感器汇总与添加传感器方法
  • Pytorch使用集成可形变卷积构建网络并导出onnx模型
  • (六)WebAPI方法的调用
  • 学习风格的类型
  • Scrapy爬虫框架 Pipeline 数据传输管道
  • 多线程---线程的状态及常用方法
  • 【9.11最新发布】Win11 24H2 26100.1742 专业版镜像!
  • 解决 Torch not compiled with CUDA enabled 问题 | MiniCPM3-4B 【应用开发笔记】
  • 阅读笔记——《围城》
  • 前后端分离项目中如何保证 API 安全
  • Vue3.0组合式API:computed计算属性、watch监听器、watchEffect高级监听器
  • 小阿轩yx-SaltStack部署与应用基础
  • ABAP-Logger ABAP 日志记录与任何其他语言一样轻松