快慢指针技巧

快慢指针技巧

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

双指针

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

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

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

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

那快慢指针是什么呢?

快慢指针

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

如图所示:

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

我们可以看到,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]代表不符合某些条件的区域
相关推荐
潇洒畅想9 分钟前
1.2 希腊字母速查表 + 公式阅读实战
java·人工智能·python·算法·rust·云计算
weixin_5134499612 分钟前
EXTREME-PARKOUR项目学习记录
人工智能·学习·算法·机器人
测绘第一深情21 分钟前
MapQR:自动驾驶在线矢量化高精地图构建的端到端 SOTA 方法
数据结构·人工智能·python·神经网络·算法·机器学习·自动驾驶
Magic--22 分钟前
C++ 智能指针
开发语言·c++·算法
Timer@25 分钟前
LangChain 教程 05|模型配置:AI 的大脑与推理引擎
人工智能·算法·langchain
sali-tec28 分钟前
C# 基于OpenCv的视觉工作流-章50-霍夫找圆
图像处理·人工智能·opencv·算法·计算机视觉
想带你从多云到转晴31 分钟前
04、数据结构与算法---双向链表
java·数据结构·算法·链表
穿条秋裤到处跑39 分钟前
每日一道leetcode(2026.04.11):三个相等元素之间的最小距离 II
算法·leetcode
Lsk_Smion1 小时前
Hot100(开刷) 之 长度最小的数组--删除倒数第N个链表--层序遍历
java·数据结构·算法·kotlin
luoganttcc1 小时前
dim3 grid_size(2, 3, 4); dim3 block_size(4, 8, 4)算例
算法