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

C++速通LeetCode中等第6题-找到字符串中所有字母异位词(滑动窗口最详细代码注释)

 滑动窗口法:

class Solution {
public:vector<int> findAnagrams(string s, string p) {unordered_map<char,int> need,window;for(char c : p) need[c]++;int left = 0,right = 0;int valid = 0;vector<int> res;//窗口数据更新while(right < s.size()){char c = s[right];right++;//先判断新来的在不在要求的字串中,不在的话计数不变if(need.count(c)){window[c]++;//再判断新来的字符计数是否满足条件了,满足条件数则valid++if(window[c] == need[c]){valid++;}}//子循环判断左窗口是否需要收缩,right-left就是当前窗口大小,因为right++导致窗口区间是[left,right)while(right - left >= p.size()){//当窗口符合条件时,把起始索引加入res,记录答案if(valid == need.size()){res.push_back(left);}char d = s[left];left++;//收缩后,对窗口计数更新//先判断舍弃的在不在要求的子串中,不在的话计数不变if(need.count(d)){   //再判断舍弃的字符计数是否满足条件了if(window[d] == need[d]){valid--;}window[d]--;//这里window一定要在判断后--,跟上面右移的时候反过来对称,右移是先++}}}return res;}
};

http://www.lryc.cn/news/444548.html

相关文章:

  • Tcping:一款实用的端口存活检测工具
  • 【每日刷题】Day130
  • 书生·浦语作业集合
  • 得物App科技创新“再上一层楼”,荣获国家级奖项
  • C#软键盘设计字母数字按键处理相关事件函数
  • C++笔记---set和map
  • HTTP 教程
  • 低代码革命:加速云原生时代的端到端产品创新
  • 力扣 92.反转链表Ⅱ
  • 2024年最新版TypeScript学习笔记——泛型、接口、枚举、自定义类型等知识点
  • java项目之城镇保障性住房管理系统(源码+文档)
  • 无人机之航线规划篇
  • 828 华为云征文|华为 Flexus 云服务器搭建 PicGo 图床
  • Zabbix 6.4添加中文语言
  • 【退役之再次线上部署】Spring Boot + VUE + Nginx + MySQL
  • Qanything 2 0源码解析系列1:新建知识库
  • Redis-01 入门和十大数据类型
  • IT行业的现状与未来发展趋势
  • 828华为云征文 | 云服务器Flexus X实例,Docker集成搭建Jenkins CI/CD平台
  • 今日 leetCode 15.三数之和
  • Games101笔记-二维Transform变换(二)
  • 【洛谷】AT_abc371_c [ABC371C] Make Isomorphic 的题解
  • 全国职业院校技能大赛(大数据赛项)-平台搭建Spark、Scala笔记
  • 【Java】JVM基本组成
  • 解决【WVP服务+ZLMediaKit媒体服务】加入海康摄像头后,能发现设备,播放/点播失败,提示推流超时!
  • 淘宝商品详情接口item_get响应参数解析:props、props_list、prop_img
  • Android使用OpenCV 4.5.0实现扑克牌识别(源码分享)
  • Pandas_iloc_loc_哪个是inclusive哪个是exclusive
  • python是什么语言写的
  • python编程,把所有子目录和文件输出到文本文件