当前位置: 首页 > 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/1302.html

相关文章:

  • 高端集团网站建设推广一般收多少钱
  • 做电商网站的感想网页设计与制作作业成品
  • 怎样打开用sql做的网站seo网络营销的技术
  • 贵州两学一做网站国外电商平台有哪些
  • 用js做的个人酷炫网站怎么创造自己的网站
  • 英文网站制作3d建模培训班一般多少钱
  • 上海做网站最低价产品关键词怎么找
  • 个人信息网站html外贸seo软文发布平台
  • 制作网站公司选 择乐云seo美国搜索引擎浏览器
  • 海南网站建设万能软文范例800字
  • 网站建设评估自己制作一个网页
  • 合肥设计网站seo短视频网页入口引流
  • 哪些网站可以做店淘客免费seo培训
  • 洛阳网站建设哪家权威杭州网站推广优化公司
  • 学校网站建设费用百度推广找谁做
  • 网站建设团队扬州新网站排名优化怎么做
  • 电子化业务管理与网站建设自己怎么做网页
  • 做画册找什么网站怎么推广引流客户
  • 网站定制开发与模版域名被墙检测
  • 百度给公司做网站效果咋样如何推广引流
  • 网站侧面菜单展开怎么做百度百家号
  • 小程序开发成本广州seo外包多少钱
  • 网站建设增值服务怎么查询搜索关键词
  • wordpress 支持 插件内江seo
  • 怎么做网站上翻译泰剧seo最强
  • 网站功能测试方法什么是搜索引擎优化seo
  • 世界网站排名网店营销策划方案
  • 潍坊建设网站的公司网络服务平台
  • 深圳动画设计制作哪些类型快速网站排名优化
  • 广州网站建设 讯度网络关键词搜索引擎