【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 ListfindAnagrams(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 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
路过按个爪印,很不错,赞一个!
[***.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
物联网 20 年简史大揭秘!
2019-04-29
开源项目|RT-Thread 软件包应用作品:水墨屏桌面台历
2019-04-29
珠联璧合!基于i.MX RT和RT-Thread的物联网云接入方案
2019-04-29
基于RTT-MicroPython制作自带BGM的新型肺炎晴雨表
2019-04-29
开源项目|RT-Thread 软件包应用作品:小闹钟
2019-04-29
在 RT-Thread Studio 上使用 RT-Thread Nano
2019-04-29
开源项目|软件包应用作品:通用物联网系统平台
2019-04-29