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

leetcode hot100:四、解题思路大全:滑动窗口(无重复字符的最长子串、找到字符串中所有字母异位词)、子串(和为k的子数组、)

滑动窗口

无重复字符的最长子串

给定一个字符串 s ,请你找出其中不含有重复字符的 最长 子串 的长度。

思路

滑动窗口+哈希表。
从左到右遍历字符串,以当前字符的下标为右边界,并不断试图往左扩宽左边界。滑动窗口内维护的就是当前字符下标为右边界的无重复字符的最长子串。答案就是返回最长的滑动窗口长度。

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

给定两个字符串 s 和 p,找到 s 中所有 p 的 异位词 的子串,返回这些子串的起始索引。不考虑答案输出的顺序。

思路

统计目标字符串 p 的字符频率:使用哈希表(Python 中的 Counter)统计 p 中每个字符的出现次数。
初始化滑动窗口:窗口大小为 p 的长度,从 s 的左侧开始滑动。
动态维护窗口内的字符频率:
每次向右滑动窗口时,移除窗口左侧的字符(频率减 1),并添加窗口右侧的新字符(频率加 1)。
比较当前窗口的字符频率与 p 的字符频率是否完全一致。

子串

和为k的子数组

给你一个整数数组 nums 和一个整数 k ,请你统计并返回 该数组中和为 k 的子数组的个数 。

子数组是数组中元素的连续非空序列。

word吗……写吐了🤮,今天写了20道题的思路了……从未有过的数量……明天再写。

相关文章:

  • 在 Excel 中使用 C# .NET 用户定义函数 操作步骤
  • linux内核编译学习笔记
  • 一文深度解析:Pump 与 PumpSwap 的协议机制与技术差异
  • 微小店推客系统开发:构建全民营销矩阵,解锁流量增长密码
  • 硬件工程师笔记——三极管Multisim电路仿真实验汇总
  • WPF技巧-常用的Converter集合(更新ing)
  • docker 查看镜像所在位置
  • python读写bin文件
  • RocketMQ 的事务消息是如何实现的
  • Transfomer学习
  • idea中,git的cherry-pick怎么用
  • 【git】git commit模板
  • 流程自动化引擎:重塑企业数字神经回路
  • 当科技邂逅浪漫:在Codigger的世界里,遇见“爱”
  • 机器学习第十八讲:混淆矩阵 → 诊断模型在医疗检查中的误诊情况
  • 企业网站架构部署与优化-Nginx网站服务
  • 了解 DDD 吗?DDD 和 MVC 的区别是什么?
  • Android 蓝牙开发 - 蓝牙相关权限(蓝牙基本权限、Android 12 蓝牙新增权限、位置权限)
  • 测试工程师要如何开展单元测试
  • 通义灵码2.5智能体模式联合MCP:打造自动化菜品推荐平台,实现从需求到部署的全流程创新
  • 三部门印发《2025年深入推进IPv6规模部署和应用工作要点》
  • 海南省市监局与香港标准及检定中心签署合作协议,加快检验检测国际化
  • 这款小孩子最爱的饮料,害处竟大到不敢想象
  • 安徽凤阳通报鼓楼瓦片脱落:2023年曾维修,已成立调查组
  • 世卫大会再次拒绝涉台提案,国台办:民进党当局再遭挫败理所当然
  • 两名游客刻划八达岭长城,被拘5日罚200元