news 2026/6/8 3:29:55

常见面试题——滑动窗口算法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
常见面试题——滑动窗口算法

按奇偶排序数组

题目理解

题目链接:按奇偶排序数组

简而言之就是把数组中所有偶数移到前面,奇数移到后面,返回任意满足条件的数组即可。

解题思路

双指针交换
用两个指针l(从0开始)和r(从l+ 1 开始)遍历数组:

  • 当 r 指向的是偶数,且 l 指向的是奇数 → 交换两者
  • 当 l 指向的是偶数 → l 右移(保证l左侧都是偶数)
  • r 不断右移遍历整个数组

代码详解

classSolution{public:vector<int>sortArrayByParity(vector<int>&nums){intn=nums.size();if(n==1){// 数组长度为1,直接返回returnnums;}intl=0;// 左指针,指向待交换的奇数位置intr=l+1;// 右指针,遍历数组找偶数while(r<n){// 右指针是偶数、左指针是奇数 → 交换if((nums[r]%2==0)&&(nums[l]%2==1)){swap(nums[r],nums[l]);}// 左指针是偶数 → 右移,扩大已排序的偶数区域if(nums[l]%2==0){l++;}r++;// 右指针继续遍历}returnnums;}};

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

题目理解

题目链接:找到字符串中所有字母异位词

给定字符串sp,找出 s 中所有是 p 的**字母异位词的子串,返回这些子串的起始索引。
(字母异位词:
字母相同但排列不同的字符串**)

解题思路

滑动窗口 + 哈希计数

因为只涉及小写字母,用两个长度为 26 的数组(hash1、hash2)分别统计 p 的字母频率、s 滑动窗口内的字母频率。通过维护一个count变量,记录窗口中有效匹配的字母数(即窗口中该字母的数量 ≤ p 中该字母的数量),当count 等于 p的长度时,说明当前窗口是 p 的异位词。

代码详解

classSolution{public:vector<int>findAnagrams(string s,string p){vector<int>ret;// 存储结果的起始索引inthash1[26]={0};// 统计p的字母频率// 第一步:初始化p的字母频率数组for(autoch:p){hash1[ch-'a']++;}inthash2[26]={0};// 统计滑动窗口内的字母频率intcount=0;// 记录窗口中有效匹配的字母数intp_len=p.size();// p的长度,用于窗口大小控制// 滑动窗口:r是右指针,l是左指针for(intl=0,r=0;r<s.size();r++){charcur=s[r];// 右指针扩大窗口:将当前字符加入hash2if(++hash2[cur-'a']<=hash1[cur-'a']){count++;// 该字符在p中且数量未超,有效匹配数+1}// 窗口大小超过p的长度,左指针缩小窗口if(r-l+1>p_len){charout=s[l++];// 左指针右移,弹出窗口左端字符if(hash2[out-'a']--<=hash1[out-'a']){count--;// 弹出的字符是有效匹配的,有效匹配数-1}}// 有效匹配数等于p的长度,说明当前窗口是异位词if(count==p_len){ret.push_back(l);// 记录起始索引l}}returnret;}};
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/5 21:12:49

27、Python 包管理工具全解析

Python 包管理工具全解析 1. 入口点与脚本安装 入口点的概念有一些复杂的方面,但从高层次来看,重要的是知道可以使用入口点将脚本作为命令行工具安装到用户路径中。要实现这一点,只需遵循特定语法并定义一个运行命令行工具的函数。 2. 在 Python 包索引中注册包 如果你编…

作者头像 李华
网站建设 2026/6/7 20:09:24

AD学习笔记-34 PCBlogo的添加

设计PCB时&#xff0c;我们有时候会添加一些logo&#xff0c;今天我们学习如何进行操作。1、图片导入我们找到放置-图形。软件会让你选定一个区域。然后我们再选中图片即可&#xff0c;是不是非常的方便。

作者头像 李华
网站建设 2026/6/8 1:23:49

9、Puppet 中的变量、表达式、事实以及 Hiera 数据管理

Puppet 中的变量、表达式、事实以及 Hiera 数据管理 1. Puppet 中的迭代:each 函数的使用 在 Puppet 中,当我们需要创建多个相似的资源时,手动编写每个资源会非常繁琐。例如,创建三个不同编号的脚本资源,除了任务编号不同外,其他属性都相同。如果后续需要修改脚本属性,…

作者头像 李华
网站建设 2026/6/7 1:45:05

电商系统中MyBatis‘小于等于‘查询实战案例

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个电商商品查询模块&#xff0c;实现按价格区间筛选商品功能。要求使用MyBatis动态SQL&#xff0c;能够查询价格小于等于指定值的商品。包含以下功能&#xff1a;1) 基础查询…

作者头像 李华
网站建设 2026/6/8 9:42:57

二叉树延伸:堆结构与 TopK 问题的深度绑定与优化

目录 前言 树 非树 树的相关术语 二叉树 二叉树的分类 计算完全二叉树和满二叉树的高度和结点数 二叉树的存储结构 顺序结构 链式结构 实现顺序结构二叉树 堆的概念与结构 堆的实现 堆的初始化 堆的值交换 获取堆顶元素、堆的数据个数、堆的判空、堆的销毁 *建…

作者头像 李华
网站建设 2026/6/8 17:32:11

企业IT实战:安全获取微软系统镜像的3种方法

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个企业级微软系统下载管理器&#xff0c;支持批量获取Windows各版本直链&#xff0c;自动验证数字签名&#xff0c;生成下载报告。包含断点续传功能和企业内网分发方案。点击…

作者头像 李华