【Leetcode刷题篇】leetcode438 找到字符串中所有字母异位词
发布日期:2021-06-29 15:35:26 浏览次数:3 分类:技术文章

本文共 1156 字,大约阅读时间需要 3 分钟。

给定一个字符串 s 和一个非空字符串 p,找到 s 中所有是 p 的字母异位词的子串,返回这些子串的起始索引。

字符串只包含小写英文字母,并且字符串 s 和 p 的长度都不超过 20100。

说明:

字母异位词指字母相同,但排列不同的字符串。
不考虑答案输出的顺序。

示例 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” 的字母异位词。

解题思路:

对p串的每个字符进行hash计数。
从下标0开始遍历字符串s,对于每个下标,判断接下来长度为pLength的子串是否为目标串的字母异位词;
判断过程为临时拷贝一份新的技术数组,然后遍历到的子串的每个字符的计数器减1,出现负数则break结束当前子串的统计,进入下一个子串的统计;
如果统计了长度为pLength的子串扔没有发现计数器减为负数的情况,说明找到了一个符合条件的字母异位词,把子串的第一个字符下标存下来。

class Solution {
public List
findAnagrams(String s, String p) {
// 对p串进行hash计数 int pLength = p.length(); int sLength = s.length(); int[] counts = new int[26]; for(int i=0;i
res = new ArrayList<>(); // 从下标0开始遍历字符串 for(int i=0;i<=sLength-pLength;i++) {
//找到临时数组 int[] tempCounts = Arrays.copyOf(counts,26); int j = i; for(;j
=pLength+i) {
res.add(i); } } return res; } }

转载地址:https://codingchaozhang.blog.csdn.net/article/details/111424612 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:【Leetcode刷题篇】leetcode49 字母异位词分组
下一篇:【Leetcode刷题篇】leetcode337 打家劫舍III

发表评论

最新留言

路过按个爪印,很不错,赞一个!
[***.219.124.196]2024年04月17日 17时08分11秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章

基于 Keil MDK 移植 RT-Thread Nano 2019-04-29
【报名截至今晚】12月14日深圳嵌入式与音频开发专题会议预告 2019-04-29
移植 RT-Thread Nano 到 RISC-V 2019-04-29
软件包应用分享|基于RT-Thread的百度语音识别(二) 2019-04-29
在 RT-Thread Nano 上添加控制台与 FinSH 2019-04-29
一站式开发工具:RT-Thread Studio 正式发布 2019-04-29
留言有礼|谢谢你悄悄点了小星星,让我们跃居GitHub RTOS Star榜第一 2019-04-29
功能更新!C 函数也能在 MicroPython 中被调用啦 2019-04-29
东软载波携ES32+RT-Thread走进海尔集团 2019-04-29
今晚8点直播预告:RT-Thread Studio等相关主题答疑 2019-04-29
Linux内核在中国大发展的黄金十年-写于中国Linux存储、内存管理和文件系统峰会十周年之际... 2019-04-29
物联网 20 年简史大揭秘! 2019-04-29
开源项目|RT-Thread 软件包应用作品:水墨屏桌面台历 2019-04-29
珠联璧合!基于i.MX RT和RT-Thread的物联网云接入方案 2019-04-29
基于RTT-MicroPython制作自带BGM的新型肺炎晴雨表 2019-04-29
Arm宣布推出Cortex-M55核心和Ethos-U55 microNPU,瞄准低功耗Edge AI 2019-04-29
开源项目|RT-Thread 软件包应用作品:小闹钟 2019-04-29
在 RT-Thread Studio 上使用 RT-Thread Nano 2019-04-29
开源项目|软件包应用作品:通用物联网系统平台 2019-04-29
【经验分享】RT-Thread UART设备驱动框架初体验(中断方式接收带\r\n的数据) 2019-04-29