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

【算法集训】基础算法:滑动窗口

定义一个快慢指针,用于截取数组中某一段信息。同时可以改变快慢指针的值来获取结果,这个过程比较像滑动。

1493. 删掉一个元素以后全为 1 的最长子数组

  • 定义快慢指针
  • 快指针先走,如果到了第二个0上的时候。前面1的个数就是fast - slow - 1,但是为了后面的继续计算,需要将slow指针+1即可。
// 滑动窗口
int longestSubarray(int* nums, int numsSize) {// 定义快慢指针int slow = 0;int fast = -1;// 记录0的个数int zero = 0;// 最大长度int maxlen = 1;// 快指针走while(fast < numsSize - 1) {fast++;zero += !nums[fast];while(zero > 1) {zero -= !nums[slow];slow++;}if(fast - slow + 1 > maxlen) {maxlen = fast - slow + 1;}}return maxlen - 1;
}

1004. 最大连续1的个数 III

和上一题一样的,只不过将替换0的值增加为了k个。

int longestOnes(int* nums, int numsSize, int k) {// 定义快慢指针int slow = 0;int fast = -1;int zero = 0;  //记录0的个数int maxlen = 0; //最终的返回的最大长度// 快指针先走while(fast < numsSize - 1) {fast ++;zero += !nums[fast];while( zero > k) {zero -= !nums[slow];slow++;}if(maxlen < fast - slow + 1) {maxlen = fast - slow + 1;}}return maxlen;
}

2730. 找到最长的半重复子字符串

int longestSemiRepetitiveSubstring(char * s){int slow = 0;int fast = -1;int same = 0;int maxlen = 0;int len = strlen(s);// 快指针while(fast < len - 1) {fast++;// 如果快大于慢的话就可以看相邻的相等否了?if(fast - slow > 0) {// 如果相等则同样记录+1if(s[fast] == s[fast - 1]) {same++;}// 当大于1的时候就需要移动慢指针了while( same > 1 ) {if(s[slow] == s[slow + 1]) {--same;}slow ++;}}if(fast - slow + 1 > maxlen) {maxlen = fast - slow + 1;}}return maxlen;
}
http://www.lryc.cn/news/329468.html

相关文章:

  • QT 二维坐标系显示坐标点及点与点的连线-通过定时器自动添加随机数据点
  • C语言TCP服务器模型 : select + 多线程与双循环单线程阻塞服务器的比较
  • 【数字IC/FPGA】手撕代码:模3检测器(判断输入序列能否被3整除)
  • 最小可行产品需要最小可行架构——可持续架构(三)
  • 笔记: 数据结构与算法--时间复杂度二分查找数组
  • AI绘画教程:Midjourney使用方法与技巧从入门到精通
  • Spring-事务管理
  • MySql实战--为什么我的MySQL会“抖”一下
  • 【蓝桥杯第十三届省赛B】(部分详解)
  • [linux初阶][vim-gcc-gdb] OneCharter: vim编辑器
  • 【Lazy ORM 框架学习】
  • 安科瑞路灯安全用电云平台解决方案【电不起火、电不伤人】
  • MYSQL——索引概念索引结构
  • Linux(CentOS7)配置系统服务以及开机自启动
  • 0 决策树基础
  • Linux速览(2)——环境基础开发工具篇(其一)
  • AWS SES发送邮件时常见的错误及解决方法?
  • 视频基础学习三——视频帧率、码率与分辨率
  • Spring(详细介绍)
  • Kettle使用
  • 互联网摸鱼日报(2024-04-01)
  • pnpm比npm、yarn好在哪里?
  • 大前端-postcss安装使用指南
  • 全局UI方法-弹窗三-文本滑动选择器弹窗(TextPickDialog)
  • LibreOffice 将word,excel,PowerPoint文件转换PDF
  • 鱼眼相机的测距流程及误差分析[像素坐标系到空间一点以及测距和误差分析]
  • 谈谈Python中的列表、元组、字典和集合的主要区别和用法
  • 【WPF应用24】C#中的Image控件详解与应用示例
  • CTF题型 php://filter特殊编码绕过小汇总
  • 【嵌入式智能产品开发实战】(十二)—— 政安晨:通过ARM-Linux掌握基本技能【C语言程序的安装运行】