Leetcode【双指针法】

目录

[一、left right在一个循环里](#一、left right在一个循环里)

二、两个指针在各自的循环里

[三、slow fast追逐型](#三、slow fast追逐型)

[四、slow fast条件型](#四、slow fast条件型)


双指针法常用与题型:数组、字符串、链表、N数之和

一、left right在一个循环里

left right在一个循环里。

left和right移动需要条件,一般是向中间移动left++,right--。对于二分法向middle位置移动。

704. 二分查找

34. 在排序数组中查找元素的第一个和最后一个位置:不用二分法会简单一点,单步移动的,而且注意for中return行的位置

344. 反转字符串:注意使用swap(char,char)函数

54. 替换数字(第八期模拟笔试):如果为了不用额外的辅助空间,可以先计算总长度,left指针倒序遍历旧数组,right指针倒序填写新数组。

15. 三数之和:值得回顾

18. 四数之和:值得回顾11. 盛最多水的容器:left和right谁小就移动谁

二、两个指针在各自的循环里

两个指针分别在各自的循环里,为了记录特征索引

941. 有效的山脉数组:left right两个指针各相对而行跑一遍,找出山峰位置,最后判断left和right能不能相遇

面试题 02.07. 链表相交:两个指针各跑一遍,为了找出两个链表的长度差

三、slow fast追逐型

slow和fast的速度不同(一般slow速度1,fast速度2),或者初始位置不同

链表:

143. 重排链表:slow速度1,fast速度2,可以方便的找到中心链表

面试题 02.07. 链表相交142. 环形链表 II:slow速度1,fast速度2,可以解决环形链表找入环位置

19. 删除链表的倒数第 N 个结点:fast先走n,slow再走n,可以找到倒数第n个节点

四、slow fast条件型

fast无脑++,而slow需要满足一定条件才能保存元素后++

数组

283. 移动零:向这种要原地修改的一看就像是要用双指针

27. 移除元素​​​​​​​

待补充..

相关推荐
hetao173383726 分钟前
2025-11-13~14 hetao1733837的刷题记录
c++·算法
hansang_IR36 分钟前
【题解】洛谷 P2476 [SCOI2008] 着色方案 [记搜]
c++·算法·记忆化搜索
趙卋傑39 分钟前
常见排序算法
java·算法·排序算法
阿巴~阿巴~1 小时前
IPv4地址转换函数详解及C++容器安全删除操作指南
linux·服务器·c++·网络协议·算法·c++容器安全删除操作·ipv4地址转换函数
TT哇1 小时前
【面经 每日一题】面试题16.25.LRU缓存(medium)
java·算法·缓存·面试
SKYDROID云卓小助手2 小时前
无人设备遥控器之差分信号抗干扰技术
网络·stm32·单片机·嵌入式硬件·算法
美狐美颜SDK开放平台2 小时前
什么是美颜sdk?美型功能开发与用户体验优化实战
人工智能·算法·ux·直播美颜sdk·第三方美颜sdk·视频美颜sdk
@宁兰2 小时前
算法实现总结 - C/C++
c语言·c++·算法
测试19982 小时前
如何用Appium实现移动端UI自动化测试?
自动化测试·软件测试·python·测试工具·ui·职场和发展·appium
Doro再努力3 小时前
2025_11_14洛谷【入门1】数据结构刷题小结
前端·数据结构·算法