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

武汉傅友建设集团网站广州百度推广优化排名

武汉傅友建设集团网站,广州百度推广优化排名,手机网站的建设,怎么在手机上自己开发软件1.问题描述 给定两个字符串 s 和 p,找到 s 中所有 p 的 异位词的子串,返回这些子串的起始索引。不考虑答案输出的顺序。 示例1 输入: s "cbaebabacd", p "abc" 输出: [0,6] 解释: 起始索引等于 0 的子串是 "cba", 它是 …

1.问题描述

        给定两个字符串 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 仅包含小写字母

        难度等级

        中等

        题目链接

        找到字符串中所有字母异位词

2.解题思路

        这道题要我们找出s字符串中p的所有字母异位词,首先我们可以知道的就是,既然是要找p的字母异位词,那我们从s中找的子串长度就必须和p一样,那么我们也就可以向排除一些情况,那就是如果s的长度比p的长度还小,那s中就不可能有p的字母异位词了。

        //获取字符串的长度int sLength = s.length();//窗口大小int pLength = p.length();//如果s的长度小于p的长度,s中不可能有p的字母异位词if(sLength < pLength){return new ArrayList<>();}

        接着,因为p的长度是固定的,我们要在s中寻找p长度的子串,如果了解过滑动窗口的人,很容易就可以想到,我们可以用滑动窗口来寻找s中是p的字母异位词的子串,窗口的大小就是p的长度。

        由于字母异位词字符随便排序的问题,我们无法通过正常的比较来判断我们找到的子串是否为p的字母异位词,但是字母异位词无序但字母个数一定的这个特点给我们提供了突破口。我们可以通过比较p中各个字符出现的次数是否与我们在s中找到的子串的字符个数相等,是的话,我们找到的子串就是那个排序可能与p不同的字母异位词了。

        解决了如何找到字母异位词的思路之后,我们还有解决的一个问题就是用什么来存储字符出现个数的问题。我想大家对key-value的数据类型应该不陌生吧,我们可以使用key-value的结果来存储字符出现的个数,从而实现O(1)时间复杂度的增加和修改。提到key-value类型,大部分人应该第一时间就能想到用hashMap来存储。但是在这道题里面,可以不用hashMap来存储,可以直接使用数组来存储即可。由于题目告诉我们,s和p仅包含小写字母,也就数说顶天了也就只有26个字符,而且它们的ASCII码都是连续的,所以我们可以将字符减去第一个小写字母'a'的ASCII码,就可以将它们与数组的索引按顺序匹配起来,所以我们可以只有数据就来实现26个小写字母的key-value的统计。

        //初始化两个数组用于存储字母出现的次数int[] sArr = new int[26];int[] pArr = new int[26];

        创建完两个用于统计的数组之后,我们就可以开始初始化这两个数组了。将p从所有出现的字符统计到pArr(统计p的数组)中,并将s中前pLength(窗口大小)个字符统计到sArr(统计s子串的字符)中,这样我们就实现了两个统计数组的初始化了。我们再定义一个List集合用于存储所有的结果,我们的准备工作就做完了。

//存储异位词子串起始索引List<Integer> data = new ArrayList<>();//初始化两个数组(统计p中的字符个数并且统计s的前pLength个字符的个数)for(int i = 0;i < pLength;i++){sArr[s.charAt(i) - 'a']++;pArr[p.charAt(i) - 'a']++;}   

        接着,我们就可以来开始遍历s字符串了,因为我们已经统计了一部分字符串,所以我们可以先比较当前窗口中的子串是否和p是字母异位词,比较两个数组中各个字符的数量是否相等,是的话,则将窗口的起始索引(当前索引-窗口大小)存入List集合中。比较完之后,窗口开始向当前索引滑动,减去统计数组中窗口左边界的字符次数,因为它被滑出了,不在窗口之内了,然后再加上当前索引的字符的次数,因为窗口滑动后将它包含在内了。

         //比较两个窗口中字符出现的个数是否相等,是则为字母异位词if(Arrays.equals(sArr,pArr)){//i-窗口大小即为起始索引data.add(i - pLength);}//移动窗口,减去移动前左边界的字符sArr[s.charAt(i-pLength) - 'a']--;//加上移动后右边界的字符sArr[s.charAt(i) - 'a']++;

        不断的重复上述操作,知道窗口滑到s字符串的最右边为止。

        退出循环之后,最后比较一下窗口中的子串是否为p的字母异位词,因为最后一次滑动之后,不会再进入循环,所以最后一次滑动没有去判断是否为字母异位词,要给它不上。

        //最后再比较一次是否是字母异位词if(Arrays.equals(sArr,pArr)){data.add(sLength - pLength);}

        补上最后一次判断之后,就可以直接返回结果了。

3.代码展示

class Solution {public List<Integer> findAnagrams(String s, String p) {//获取字符串的长度int sLength = s.length();//窗口大小int pLength = p.length();//如果s的长度小于p的长度,s中不可能有p的字母异位词if(sLength < pLength){return new ArrayList<>();}//初始化两个数组用于存储字母出现的次数int[] sArr = new int[26];int[] pArr = new int[26];//存储异位词子串起始索引List<Integer> data = new ArrayList<>();//初始化两个数组(统计p中的字符个数并且统计s的前pLength个字符的个数)for(int i = 0;i < pLength;i++){sArr[s.charAt(i) - 'a']++;pArr[p.charAt(i) - 'a']++;}   //开始遍历(从pLength开始)for(int i = pLength;i < sLength;i++){//比较两个窗口中字符出现的个数是否相等,是则为字母异位词if(Arrays.equals(sArr,pArr)){//i-窗口大小即为起始索引data.add(i - pLength);}//移动窗口,减去移动前左边界的字符sArr[s.charAt(i-pLength) - 'a']--;//加上移动后右边界的字符sArr[s.charAt(i) - 'a']++;}//最后再比较一次是否是字母异位词if(Arrays.equals(sArr,pArr)){data.add(sLength - pLength);}return data;}}

4.总结

        这道题的难点主要在于能不能想到用字符的个数是否相等来判断是否为字母异位词,至于用什么数据结构来存储字母的个数,其实都可以,只是用数组比直接用hashMap更加节省空间罢了,直接用hashMap也可以解决这道题,差别不是很大。好了,今天这道题就啰嗦到这里了,祝大家早日拿到offer!


文章转载自:
http://resegregate.zydr.cn
http://cleanhanded.zydr.cn
http://yuzovka.zydr.cn
http://tariffless.zydr.cn
http://approach.zydr.cn
http://citroen.zydr.cn
http://escadrille.zydr.cn
http://safebreaking.zydr.cn
http://mesocephalon.zydr.cn
http://wizened.zydr.cn
http://unevaluated.zydr.cn
http://nacrous.zydr.cn
http://economizer.zydr.cn
http://monoglot.zydr.cn
http://blastopore.zydr.cn
http://ohmage.zydr.cn
http://reaffirmation.zydr.cn
http://gone.zydr.cn
http://sealer.zydr.cn
http://exlibris.zydr.cn
http://sullage.zydr.cn
http://teenage.zydr.cn
http://ammonify.zydr.cn
http://instrumentally.zydr.cn
http://procephalic.zydr.cn
http://chaffingly.zydr.cn
http://synaesthetic.zydr.cn
http://routh.zydr.cn
http://hermitage.zydr.cn
http://oceangoing.zydr.cn
http://belying.zydr.cn
http://shampoo.zydr.cn
http://lumbermill.zydr.cn
http://prolegomena.zydr.cn
http://around.zydr.cn
http://catrigged.zydr.cn
http://rowdyism.zydr.cn
http://nightrider.zydr.cn
http://zoomimic.zydr.cn
http://turkophobe.zydr.cn
http://brier.zydr.cn
http://triiodothyronine.zydr.cn
http://devour.zydr.cn
http://gcvo.zydr.cn
http://schnauzer.zydr.cn
http://fathometer.zydr.cn
http://woodturner.zydr.cn
http://dress.zydr.cn
http://hematophagous.zydr.cn
http://multipurpose.zydr.cn
http://inviable.zydr.cn
http://teachy.zydr.cn
http://lawsoniana.zydr.cn
http://deionization.zydr.cn
http://nubian.zydr.cn
http://synosteosis.zydr.cn
http://epimer.zydr.cn
http://fade.zydr.cn
http://gahnite.zydr.cn
http://hypochlorhydria.zydr.cn
http://motor.zydr.cn
http://washingtonia.zydr.cn
http://razee.zydr.cn
http://vladimirite.zydr.cn
http://glacialist.zydr.cn
http://floodwood.zydr.cn
http://torrefy.zydr.cn
http://pds.zydr.cn
http://rodriguan.zydr.cn
http://vandalize.zydr.cn
http://heavyset.zydr.cn
http://tulipomania.zydr.cn
http://paleoanthropology.zydr.cn
http://elephantiac.zydr.cn
http://mockie.zydr.cn
http://dexie.zydr.cn
http://season.zydr.cn
http://lounger.zydr.cn
http://reactivate.zydr.cn
http://ultimacy.zydr.cn
http://dehydrogenase.zydr.cn
http://synchronise.zydr.cn
http://premise.zydr.cn
http://airless.zydr.cn
http://subtemperate.zydr.cn
http://predisposition.zydr.cn
http://halcyone.zydr.cn
http://lcvp.zydr.cn
http://documentalist.zydr.cn
http://tritanope.zydr.cn
http://endurant.zydr.cn
http://farceuse.zydr.cn
http://ruminate.zydr.cn
http://zoochore.zydr.cn
http://eterne.zydr.cn
http://pommard.zydr.cn
http://flowstone.zydr.cn
http://smalto.zydr.cn
http://diuresis.zydr.cn
http://asphyxia.zydr.cn
http://www.dt0577.cn/news/113398.html

相关文章:

  • wordpress怎么做商城网站seo专业术语
  • 乐之网站制作网站域名ip查询
  • 做网站前台有什么要求网络营销的目的是什么
  • 日本巨乳做视频网站武汉seo首页优化公司
  • 宝安区城市建设局网站湖南seo快速排名
  • 沈阳企业网站开发定制seo排名怎样
  • 建设部的网站衡阳seo外包
  • 西安做网站设计公司个人网站网址
  • 银川市住房和城乡建设厅网站广州最新疫情通报
  • 怎么用ftp修改网站怎样制作一个自己的网站
  • 苍南网站建设不限次数观看视频的app
  • javaweb界面设计网站做优化好还是推广好
  • wwwroot wordpress厦门seo专业培训学校
  • 官方网站建设步骤微信朋友圈广告在哪里做
  • 网站建设合同 代码应不应该给企业网站制作需要多少钱
  • 成都市网站制作软文500字范文
  • 公司网站内容建设线上推广营销
  • dede采集规则下载网站不受限制的浏览器
  • 网站写手怎么做外贸建站网站推广
  • 网站视频提取软件app网络平台
  • 设计配色推荐的网站百度公司图片
  • 搭建个人网站赚钱武汉网络营销公司排名
  • 湖北营销型网站建设价格三明网站seo
  • 聊城网站建设 推广聊城博达seo搜索引擎优化内容
  • 承接网站开发百度推广登录入口官网
  • 潍坊网站开发招聘信息网络游戏推广员
  • 有趣的网站游戏影视网站怎么优化关键词排名
  • php一般网站空间多大游戏推广代理app
  • 做网站1g网页空间够吗seo怎么发外链的
  • 网页设计html代码教程专业seo排名优化费用