算法中的双指针使用,有时候会觉得很巧妙,解决了很多的问题,有必要归纳总结一下,首先双指针也是个很宽泛的概念,它类似于遍历中的 i 和 j
但是其区别是,两个指针是同时移动的,即没有贡献复杂度从O(N)
到 O(N*N)
,所以被很多算法大佬所推崇,所以基于此归纳总结出双指针的常见解法和套路。
1.题型归纳
这里将题型归纳为三种,分别如下:
快慢指针(前后按不同步调的两个指针)
前后双端指针(一个在首,一个在尾部,向中间靠拢)
固定间隔的指针(以i, i + k的间距的两个指针)
前面讲到,这三种指针都是遍历一次数组即可完成,其时间复杂度低于或者等于O(N)
,空间复杂度是O(1)
因为就两个指针存储。
2.常见题型
2.1快慢指针
相当经典的一道题:
- 判断链表是否有环-
通过步调不一致的两个指针,一前一后一起移动,直到指针重合了
https://leetcode.com/problems/linked-list-cycle/description,代码片段如下: