关于 LeetCode 系列有段时间没有逐题更新了 ,还是想到一题一题的刷有些凌乱 。如前段时间的推文所说 ,准备系统的讲讲数据结构相关知识点 。
今天想要分享的是在刷题中频繁遇到的一个知识点——双指针问题 。杠精读者有没有 ?
指针 ?博主你又在扯蛋 ,Python 没有指针好的伐 !
的确是 ,Python 中没有指针的概念 。刷前几题的时候遇到过链表问题 ,有读者就对链表问题表示困惑 ,其实根本原因就在这 。Python 中用的就是模拟指针 ,所以链表也是模拟链表哟 。
双指针说白了就是两个指针指向两个地址 ,可能是移动速度不同 ,可能是指向不同的节点(元素)。用这种方式去解决一些实际问题 。
⒈
合并问题 。比如给定两个有序数组 ,要求将两个有序数组进行合并 ,合并成一个有序数组 。其实有点类似之前刷过的第 4 题 :
当时写的代码不够优化美观 ,但是这类合并问题都可以用到双指针思路解决噢 。
⒉
链表是否有环问题 。链表也是我们所常见的一个数据结构了 ,判断一个链表是否有环就可以用双指针思路解决 。这个在 LeetCode 的第 141 题 。
⒊
原地移除重复元素 。这也是 LeetCode 上比较经典也比较容易的问题 。给定一个排序数组 ,要求删除其中的重复项 。同类型的还有删除给定值 。这两题在 LeetCode 的第 26 和第 27 题 :
⒋
奇偶排序 。一个公司的面试题 ,给定一个数组 ,有奇数也有偶数 ,要通过处理将奇数放在左边 ,偶数在右边 。这个也可以通过双指针思路进行解决 。
参考代码如下 :
⒌
关于双指针的应用还有很多呀 ,欢迎读者小伙伴们一起留言区补充交流 。