[LeetCode]Find All Anagrams in a String

[LeetCode]Find All Anagrams in a String

大家好,又见面了,我是全栈君。

Find All Anagrams in a String
Given a string s and a non-empty string p, find all the start indices of p’s anagrams in s.

Strings consists of lowercase English letters only and the length of both strings s and p will not be larger than 20,100.

The order of output does not matter.

Example 1:

Input:
s: "cbaebabacd" p: "abc"

Output:
[0, 6]

Explanation:
The substring with start index = 0 is "cba", which is an anagram of "abc".
The substring with start index = 6 is "bac", which is an anagram of "abc".
Example 2:

Input:
s: "abab" p: "ab"

Output:
[0, 1, 2]

Explanation:
The substring with start index = 0 is "ab", which is an anagram of "ab".
The substring with start index = 1 is "ba", which is an anagram of "ab".
The substring with start index = 2 is "ab", which is an anagram of "ab".

1.解题思路

anagrams,就是只顺序不同但个数相同的字符串,那我们就可以利用hashtable的思想来比较每个字符串中字符出现的个数是否相等。
对于两个字符串我们分别准备数组(大小为256)来存储每个字符出现的次数:
1) 对于p,我们遍历,并在hp中记录字符出现的次数;
2) 之后遍历s,先把当前字符的个数+1,但是需要考虑当前index是否已经超过了p的长度,如果超过,则表示前面的字符已经不予考虑,所以要将index-plen的字符的个数-1;最后判断两个数组是否相等,如果相等,返回index-plen+1,即为开始的下标。

2.代码

public class Solution {
    public List<Integer> findAnagrams(String s, String p) {
        List<Integer> res=new ArrayList<Integer>();
        if(s.length()==0||s==null||p.length()==0||p==null) return res;
        int[] hs=new int[256];
        int[] hp=new int[256];
        int plen=p.length();
        for(int i=0;i<plen;i++){
            hp[p.charAt(i)]++;
        }
        for(int j=0;j<s.length();j++){
            hs[s.charAt(j)]++;
            if(j>=plen){
                hs[s.charAt(j-plen)]--;
            }
            if(Arrays.equals(hs,hp))
                res.add(j-plen+1);
        }
        return res;
    }
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/108772.html原文链接:https://javaforall.net

(0)
上一篇 2022年2月22日 下午6:00
下一篇 2022年2月22日 下午6:00


相关推荐

  • OpenClaw(Moltbot)本地安装步骤与2026年云上一键部署流程攻略

    OpenClaw(Moltbot)本地安装步骤与2026年云上一键部署流程攻略

    2026年3月13日
    3
  • CentOS 7安装教程(图文详解)

    CentOS 7安装教程(图文详解)CentOS7安装教程: 准备:软件:VMwareWorkstation镜像文件:CentOS-7-x86_64-bin-DVD1.iso(附:教程较为详细,注释较多,故将操作的选项进行了加粗字体显示。) 1、文件–新建虚拟机–自定义2、…

    2022年6月13日
    65
  • 计算机msvcr110.dll,msvcr110.dll

    计算机msvcr110.dll,msvcr110.dllmsvcr110 dll 是计算机的中的一个程序文件 当缺失这个文件时 启动某些程序可能会出现错误 严重影响了用户的正常使用 通常此时 需要用户自行下载 msvcr110 dll 并放在指定位置以解决问题 假如你也遇到了这个问题 就快来下载吧 msvcr110 dll 常见情况 1 程序无法启动 因为您的计算机缺少 msvcr110 dll 尝试重新安装程序来解决这个问题 2 启动 msvcr110 dll

    2026年3月20日
    2
  • 双目视觉三维重建框架

    双目视觉三维重建框架一 图像坐标 我想和世界坐标谈谈 A 玉米竭力用轻松具体的描述来讲述双目三维重建中的一些数学问题 希望这样的方式让大家以一个轻松的心态阅读玉米的 计算机视觉学习笔记 双目视觉数学架构系列博客 这个系列博客旨在捋顺一下已标定的双目视觉中的数学主线 数学推导是有着几分枯燥的 但奇妙的计算机视觉世界是建立在严密的数学架构之上的 所以对数学框架的理解是理解双目视觉的必由之路 不过请大家放心 接下来

    2026年3月18日
    2
  • 【C语言】动态分配二维字符串数组

    【C语言】动态分配二维字符串数组动态分配一个二维字符串数组 1 分配可能不连续的内存申请 charpps8Outp char malloc n sizeof char 对于 pps8Output 而言 它获得了一块动态分配的连续内存 这块连续的内存可以放 n 个 char 指针 下面为每一行 malloc 一次内存 这样分配的内存就不一定是连续的 for inti 0 i

    2026年3月19日
    2
  • Postman用法简介

    Postman用法简介Postman 用法简介 Http 请求模拟工具 在我们平时开发中 特别是需要与接口打交道时 无论是写接口还是用接口 拿到接口后肯定都得提前测试一下 这样的话就非常需要有一个比较给力的 Http 请求模拟工具 现在流行的这种工具也挺多的 像火狐浏览器插件 RESTClient Chrome 浏览器插件 Postman 等等 这里主要介绍一下 Postman nbsp 一 Postman 说明

    2025年10月10日
    8

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号