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

广西钦州有人帮做网站的公司吗找人做试管婴儿的网站

广西钦州有人帮做网站的公司吗,找人做试管婴儿的网站,wordpress影音主题,湘潭市网站建设科技有限公司LeetCode-滑动窗口-找到字符串中所有字母异位词 ✏️ 关于专栏:专栏用于记录 prepare for the coding test。 文章目录 LeetCode-滑动窗口-找到字符串中所有字母异位词📝 找到字符串中所有字母异位词🎯题目描述🔍 输入输出示例&am…

618224d51d66b92b423588150f25f3a7-1746706818078-1-1746790482186-1-1746797747208-4

LeetCode-滑动窗口-找到字符串中所有字母异位词

✏️ 关于专栏:专栏用于记录 prepare for the coding test


文章目录

  • LeetCode-滑动窗口-找到字符串中所有字母异位词
    • 📝 找到字符串中所有字母异位词
      • 🎯题目描述
      • 🔍 输入输出示例
      • 🧩题目提示
      • 🧪滑动窗口—定长
      • 🧪滑动窗口—变长
      • 🌟 总结
        • 🔁 相似题目推荐(逐步进阶)

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

🎯题目描述

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

🧪滑动窗口—定长

本题适合使用 定长滑动窗口,即窗口长度固定为 p.size(),从左往右滑动,每次滑动判断当前窗口是否是异位词。

我们用两个长度为 26 的数组来统计字母频次(因为仅包含小写字母),当两个数组相等时(array支持 = = == ==​直接比较),说明当前窗口是 p 的异位词。

1.预处理字符串 p 的字符频率,用一个长度为 26 的数组 cnt_p 存储。

2.滑动窗口遍历 s,维护当前窗口内的频率数组 cnt_s

3.若 cnt_scnt_p 相等,则窗口起始位置是一个异位词。

image-20250519114327236

class Solution {
public:vector<int> findAnagrams(string s, string p) {vector<int> ans;array<int,26> cnt_s {};array<int,26> cnt_p {};for(char c : p){cnt_p[c - 'a']++;}for(int right = 0;right < s.size();right++){cnt_s[s[right] - 'a']++;int left = right - p.size() + 1;if(left >= 0){if(cnt_s == cnt_p){ans.push_back(left);}cnt_s[s[left]-'a']--;}else{continue;}}return ans;}
};

🧪滑动窗口—变长

相比固定窗口的方法,我们也可以用灵活窗口(变长)去尝试:

  • 每次将右指针加入窗口,并对字符频率计数;
  • 若某个字符频率多了,就不断移动左指针直到频率合法;
  • 当窗口长度等于 p.size(),说明找到一个异位词。
class Solution {
public:vector<int> findAnagrams(string s, string p) {vector<int> ans;array<int,26> cnt {};for(char c : p){cnt[c - 'a']++;}int left = 0;for(int right = 0;right < s.size();right++){int c = s[right] - 'a';cnt[c]--;while(cnt[c] < 0){cnt[s[left] - 'a']++;left++;}if(right - left + 1 == p.size()){ans.push_back(left);}}return ans;}
};

🌟 总结

  • 使用字符频率数组作为滑动窗口核心;

  • 左指针控制窗口合法性,右指针推动遍历;

  • 比较频率数组是否一致,作为是否匹配的判断依据。

滑动窗口维度技巧要点
指针控制一般使用 leftright 两个指针定义区间 [left, right][left, right)
窗口内数据维护统计频率、子串长度、计数器(如满足条件的字符个数)等
何时收缩窗口取决于当前窗口是否满足题意或已经不合法
何时记录结果当窗口满足题意时保存起始索引或其他信息
知识点简要描述
滑动窗口一种通过左右指针控制子串区域的技巧,适合处理子串/子数组问题
字符频率匹配通过数组或哈希表统计字符出现次数,判断是否为异位词
固定长度滑窗每次窗口长度固定,对新字符加入、旧字符移出,保持频率平衡
数组比较std::array<int, 26> 支持 == 运算,效率高于 unordered_map
🔁 相似题目推荐(逐步进阶)
难度题目题目编号技巧
🌱 简单字符串的排列567判断是否包含某异位词
🌿 中等本题438找出所有异位词起始位置
🌳 中等最小覆盖子串76滑窗 + 字符要求计数器
🌲 困难串联所有单词的子串30复杂频率统计、窗口倍增

473a45227a39b7ec06f6525e7ebb85b

http://www.dtcms.com/wzjs/556901.html

相关文章:

  • 江苏交通运输厅网站建设在家做网站或ps挣钱接活
  • 手机主题制作网站企业网站尺寸
  • 自贡企业网站建设生活中的网络营销有哪些
  • 网上如何建网站卖量具乐客vr加盟费用要多少
  • wordpress 建站案例微网站模板前后台
  • 怎么给网站图片加alt在英特尔上建设网站可选择的方案有
  • wordpress获取浏览人信息上海seo公司排名榜
  • 网站建设必要步骤网站建设功能图
  • 如何建立自己网站教程免费域名申请哪个网站好
  • 海口网站建设介绍合肥网站建设多少钱
  • 网站开发工程师薪资app网站下载免费
  • wordpress做下载站中国商标网官网首页
  • 网站如何做电脑和手机软件做公司网站域名怎么做记账凭证
  • 帮别人做网站 别人违法青岛如何建立企业网站企业
  • 从哪看出网站的建站公司wordpress高级插件
  • 学校网站建设学生文明上网学院网站建设目标
  • 网站的英文wordpress的首页设置
  • 网站平台建设的实训报告网站免费推广网站
  • 公司如何做网站一般多少钱网站seo啥意思
  • 建设网站以后强大的wordpress 二次开发
  • 制作网站的设计难点智慧团建网站密码
  • 公司集团网站设计做视频上传多少个网站
  • php支持大型网站开发吗网站服务器管理 硬件
  • 河间市网站建设公司网站建立初步
  • 夺宝网站建设网站建设课设
  • 建网站需要软件制作灯笼的心得体会
  • 做品牌特卖的网站免费云主机哪个好
  • wordpress 中文站p2p网站开发的内容
  • 食品 技术支持 东莞网站建设wordpress添加附件下载
  • 乐山 做网站用ps软件做ppt模板下载网站有哪些