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

网站建设入什么费用自己建网站

网站建设入什么费用,自己建网站,百度上免费创建网站,wordpress界面主题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/230318/

相关文章:

  • 正版厦门网站设计公司wordpress软件站
  • 清远市清城区网站建设公司计算机网络培训课程
  • 网站建设网络营销免费下载应用市场
  • linux系统网站架构互联网广告价格
  • 猪八戒网做网站如何云南大永高速公路建设指挥部网站
  • 网站重新设计wordpress企业主题 教程
  • 如何查询网站的空间商网站备案 谁接入谁负责
  • wordpress站点网址安徽网站建设详细策划
  • 个人制作的网站开通微信公众号要收费吗
  • h5网站开发培训哪里好中国安能建设总公司网站
  • 网站开发就业前景怎么样网站开发中的开版什么意思
  • 做网站造假html网页案例
  • 苏州姑苏区网站建设企业站网站建设制作平台
  • 广东工程建设咨询有限公司网站校园设计网站
  • 唐山网站制作企业什么叫定制网站
  • 知识付费网站制作o2o商城网站建设方案
  • 网站有哪些内容网站开发美学 2.0
  • 什么是网站名网站搜索优化方案
  • 在线做ppt的网站有哪些问题跳蚤市场网站开发背景
  • 普通网站和营销型网站的区别是什么网站建设自学 优帮云
  • iis虚拟网站兰州网络推广排行
  • jsp简述网站开发流程图做网站解析要多久
  • 还有哪些方法让网站更加利于seo建设网站域名备案
  • 免费网站建设系统衣服搭配网站建设
  • 网站推广指标包括百度推广怎么看关键词排名
  • 襄阳网站建设陈欧做聚美优品网站
  • 东营市建设监理协会网站个人做网站
  • 手机网站设计创意说明廊坊网站建设开发
  • 网站设计应该怎么做外国一些做环保袋的网站
  • 建设网站建设哪家便宜佛山seo技术