程序员社区

玩转双指针

双指针主要用于遍历数组,两个指针指向不同的元素,从而协同完成任务。 常见的双指针有三种。

  • 左右指针:两个指针指向同一数组,但是遍历方向相反,常用作搜索排序数组的两个符合条件的数,以及其他特殊情况。
  • 快慢指针:两个指针指向同一数组,遍历方向相同,fast指针快,slow慢。然后它俩同时向前移动,初始的时候相隔一定的距离,这个距离一般由题意选择。用在特殊链表
  • 滑动窗口:两个指针指向同一数组,遍历方向相同且不会相交(两个指针包围的区域即为当前的窗口),经常用于区间搜索

一.左右指针

搜索排序数组(基础版):玩转双指针插图

 

 搜索排序数组(升级版):玩转双指针插图1

 

 其他场景:

玩转双指针插图2  

玩转双指针插图3

 

 二.快慢指针

 链表倒数第k个节点:快指针先走n步,然后和慢指针每次移动1位

  其他方法:遍历所有节点,求第count - k个节点;反转链表;放入栈中;玩转双指针插图4

 

玩转双指针插图5

 

 环形链表:快指针和慢指针在同一个位置,但是快指针每次移动2步,慢指针每次移动1位玩转双指针插图6

 

玩转双指针插图7

模拟的环形链表

玩转双指针插图8

 

 回文链表:其他方法:把链表遍历放在一个数组中,使用左右指针比较。缺点:空间复杂度O(n)玩转双指针插图9

 

 三.滑动窗口

正向滑动窗口

玩转双指针插图10

 

 玩转双指针插图11

反向滑动窗口 

玩转双指针插图12

 特殊滑动窗口:需要的元素不是窗口内的元素,而是窗口的左右边界

玩转双指针插图13

 

玩转双指针插图14

 

 寄语:读一些无用的书,做一些无用的事,花一些无用的时间,都是为了在一切已知之外,保留一个超越自己的机会。

赞(0) 打赏
未经允许不得转载:IDEA激活码 » 玩转双指针

一个分享Java & Python知识的社区