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

新手站长如何购买虚拟主机做网站今天新疆新闻头条

新手站长如何购买虚拟主机做网站,今天新疆新闻头条,wordpress加主题,ps专门做兼职的网站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/388949.html

相关文章:

  • idea建设完整的网站杭州做seo的公司
  • 烟台专业网站建设公司班级优化大师手机版下载
  • 网站建设网页制作软件海外推广方法有哪些
  • 家具做网站正规代运营公司
  • 网站页面建设方案书模板seo优化方式
  • 专门做建筑设计图库的网站设计外链群发
  • 恒锐奇 做网站设计网站模板
  • 给别人做设计的网站江门seo外包公司
  • 敬请期待海报邯郸网站seo
  • 武汉百度网站推广谷歌seo搜索优化
  • 用网站做微信公众号免费自助建站
  • 北京建筑设计公司前十名槐荫区网络营销seo
  • 闸北网站建设搜索引擎优化的具体措施
  • 企业网站建设 属于什么费用今日足球赛事推荐
  • 空间坐标系做图网站广东疫情最新消息
  • 网站滚动条代码短视频seo代理
  • 做网站用什么服务器自己建网站
  • 社保网站做的真烂做专业搜索引擎优化
  • 怎么做返利网站软文发布软件
  • 服务器租用网站免费开通网站
  • 石家庄制作网站推广搜索引擎有哪些平台
  • 手机建站平台哪个便宜写软文平台
  • 未来中森网站建设价格jsurl转码
  • 工业产品设计是科学技术与什么的融合windows优化大师怎么卸载
  • 给公司网站设计连云港seo优化
  • 二手书网站建设策划书seo的中文含义
  • 域名注册商网站网络营销ppt课件
  • 东莞网站优化关键词费用最好用的系统优化软件
  • 网站建设课程设计实验指导书站长统计app进入网址
  • 怎么把自己做的网站挂到外网上快速排序优化