算法-双指针问题解决思路

算法中的双指针使用,有时候会觉得很巧妙,解决了很多的问题,有必要归纳总结一下,首先双指针也是个很宽泛的概念,它类似于遍历中的 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,代码片段如下:


                
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值