快慢指针技巧

快慢指针技巧

在说快慢指针 之前,我们先说一下双指针

双指针

双指针:使用两个指针来解决问题。

所谓的指针其实就是指数组的下标,或者链表的节点的地址。

我们以数组为例介绍一下。

有两个指针分别存储着数组的两个下标,这就是双指针。

那快慢指针是什么呢?

快慢指针

快慢指针,就是一个指针走得慢,另一个指针走得快。

如图所示:

这实际上就是快慢指针,一个走得慢,一个走得快。

我们可以看到,fast指针把整个大数组分成了两个区域:

markdown 复制代码
[0,fast-1]代表已处理的区域
[fast,n-1]代表未处理的区域

同时,已处理区域又被slow指针划分为了两个区域:

markdown 复制代码
[0,slow-1]代表符合某些条件的区域
[slow,fast-1]代表不符合某些条件的区域

处理逻辑

每一轮处理fast指针指向的元素,

如果元素不符合某种条件,fast++,向后移动。

如果元素符合某种条件,可能会和slow指针指向的元素进行某些运算,比如交换;

然后快慢指针同时向后移动;

直到fast指针移出数组,如图:

slow和fast指针,可以称为:循环不变量。因为它们在循环的时候的含义是不会变的。

始终遵守,如下条件:

markdown 复制代码
[0,fast-1]代表已处理的区域
[fast,n-1]代表未处理的区域

[0,slow-1]代表符合某些条件的区域
[slow,fast-1]代表不符合某些条件的区域
相关推荐
bai_lan_ya8 小时前
使用linux的io文件操作综合实验_处理表格
linux·服务器·算法
计算机安禾8 小时前
【C语言程序设计】第36篇:二进制文件的读写
c语言·开发语言·c++·算法·github·visual studio code·visual studio
ZPC82108 小时前
OLOv11 + 深度相机的方案实现高精度3D定位
人工智能·数码相机·算法·机器人
_日拱一卒8 小时前
LeetCode:字母异位词分组
算法·leetcode·职场和发展
Dfreedom.8 小时前
机器学习经典算法全景解析与演进脉络(监督学习篇)
人工智能·学习·算法·机器学习·监督学习
2301_807367198 小时前
C++代码风格检查工具
开发语言·c++·算法
Morwit8 小时前
*【力扣hot100】 215. 数组中的第K个最大元素
数据结构·c++·算法·leetcode·职场和发展
奔袭的算法工程师8 小时前
用AI写天线阵列排布算法
人工智能·算法·信号处理
ab1515178 小时前
3.20二刷基础121、127,完成进阶61、62
数据结构·算法·排序算法
I_LPL8 小时前
day58 代码随想录算法训练营 图论专题11
数据结构·算法·图论