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

wordpress收录p济南seo网站关键词优化排名

wordpress收录p,济南seo网站关键词优化排名,seo技术手段,莱芜金点子最新租房信息1. 题目链接:438. 找到字符串中所有字母异位词 2. 题目描述: 给定两个字符串 s 和 p,找到 s 中所有 p 的 异位词 的子串,返回这些子串的起始索引。不考虑答案输出的顺序。 异位词 指由相同字母重排列形成的字符串(包括…

1. 题目链接:438. 找到字符串中所有字母异位词

2. 题目描述:

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

3. 解法(滑动窗口+哈希表)

3.1 算法思路:

  • 因为字符串p的异位词的长度一定与字符串p的长度相同,所以我们可以在字符串s中构造一个长度为与字符串p的长度相同的滑动窗口,并在滑动中维护窗口中每种字母的数量
  • 当窗口中每种字母的数量与字符串p中每种字母的数量相同时,则说明当前窗口为字符串p的异位词
  • 因此可以用两个大小为26的数组来模拟哈希表,一个来保存s中的子串每个字符出现的个数,
  • 另一个来保存p每一个字符出现的个数。这样就能判断两个串是否是异位词

3.2 算法流程:

  1. 初始化hash1数组,用来统计字符串p中每个字符出现的次数。
  2. 初始化hash2数组,用来统计滑动窗口内每个字符出现的次数。
  3. 将滑动窗口的左边界left和右边界right都初始化为0
  4. 遍历字符串s,从左到右依次将字符加入窗口。
  5. 判断是否需要移动窗口。如果窗口长度超过了p的长度,就需要移动窗口,判断是否需要从窗口中移出最左边的字符。
  6. 如果需要移出字符,就从窗口中移出最左边的字符,并更新hash2数组和count变量。
  7. 判断窗口内的字符是否是p的异位词。如果是,将左边界的索引加入结果数组ret
  8. 返回结果数组ret

请添加图片描述

3.3 C++算法代码:

class Solution {
public:vector<int> findAnagrams(string s, string p) {vector<int> ret;int hash1[26]={0};//统计字符串p中每个字符出现的次数for(auto ch:p)hash1[ch-'a']++;int hash2[26]={0};//统计窗口里面的每个字符出现的个数int m=p.size();for(int left=0,right=0,count=0;right<s.size();right++){char in=s[right];if(++hash2[in-'a']<=hash1[in-'a'])count++;//进窗口+维护countif(right-left+1>m)//判断{char out=s[left++];if(hash2[out-'a']--<=hash1[out-'a'])count--;//出窗口+维护 count}//更新结果if(count==m)ret.push_back(left); }return ret;}
};
http://www.yayakq.cn/news/792131/

相关文章:

  • 重庆网站建设公司电话万网域名注册官网中文域名
  • 厦门seo网站排名优化wordpress 模版修改
  • 电子商务网站建设与管理的背景建设工程评标专家在哪个网站登录
  • 网站怎样自动文字排版263企业会议邮箱登录入口
  • 渠县网站建设打开app查看全部
  • 专业提供网站建设服务包括哪些建立网站的软件下载
  • 找公司做网站多少钱成都手游开服网
  • 免费企业网站源码大全企业网站个人备案吗
  • 邢台中北世纪城网站兼职深圳网站公司建设
  • 代做毕业设计网站现成一流的高密网站建设
  • 深圳住房与建设局官方网站国内网站要备案
  • 阳山县网站住房和建设局建设集约化网站的进展情况
  • 如何快速做企业网站包括商城wordpress怎么修改中文字体
  • 公司网站是用什么软件做怎么改版一个网站
  • 免费做企业推广的网站公司网站建设的费用如何入账
  • 学校网站页面设计wordpress+发布文章慢
  • 阿里云虚拟主机建站教程德阳做网站的
  • 服务好的网站制作wordpress插图插件
  • 合肥网站建设渠道网站应如何设计
  • 网站手册网站推广服务合同模板
  • 设计广告网站自助单页网站
  • jsp 交互网站开发技术 西安交通大学出版社 2005.10服务器网站访问慢
  • 两个域名同一个网站做优化网站主体负责人不是法人
  • 成都网站优化方式中国电子商务平台
  • godaddy 搭建网站数据分析师报名官网
  • 网站建设属开票核定税种cc在线代理
  • 电子商务的网站建设要求步骤网页制作软件山水
  • 中企动力网站优化常州网站建设czyzj
  • 做的网站没流量吗阳新县建设局网站
  • 网站开发技术技巧网站模板切换