前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LeetCode 系列——双指针问题 。

LeetCode 系列——双指针问题 。

作者头像
小小詹同学
发布2018-12-17 16:14:01
1.3K0
发布2018-12-17 16:14:01
举报
文章被收录于专栏:小詹同学小詹同学

关于 LeetCode 系列有段时间没有逐题更新了 ,还是想到一题一题的刷有些凌乱 。如前段时间的推文所说 ,准备系统的讲讲数据结构相关知识点 。

刷 LeetCode 那点事 !

今天想要分享的是在刷题中频繁遇到的一个知识点——双指针问题 。杠精读者有没有 ?

指针 ?博主你又在扯蛋 ,Python 没有指针好的伐 !

的确是 ,Python 中没有指针的概念 。刷前几题的时候遇到过链表问题 ,有读者就对链表问题表示困惑 ,其实根本原因就在这 。Python 中用的就是模拟指针 ,所以链表也是模拟链表哟 。

双指针说白了就是两个指针指向两个地址 ,可能是移动速度不同 ,可能是指向不同的节点(元素)。用这种方式去解决一些实际问题 。

合并问题 。比如给定两个有序数组 ,要求将两个有序数组进行合并 ,合并成一个有序数组 。其实有点类似之前刷过的第 4 题 :

LeetCode | 两个有序数组的中位数

当时写的代码不够优化美观 ,但是这类合并问题都可以用到双指针思路解决噢 。

  • 分别定义两个 “指针” ,指向两个数组(list_1;list_2)的首位 。再定义一个新数组(列表list_3)用于存储最终结果 。
  • 将指针指向的两个元素进行比较 ,将较小的元素 copy 到 list_3 中 。
  • 将元素较小的数组指针右移一位 ,继续比较 。直到 list_1 或者list_2 中某一个所有元素都遍历完 ,将另一个剩下的所有元素 copy 到 list_3 即可 。

链表是否有环问题 。链表也是我们所常见的一个数据结构了 ,判断一个链表是否有环就可以用双指针思路解决 。这个在 LeetCode 的第 141 题 。

  • 定义两个指针 ,一快一慢 。比如慢指针一次移动 1 个位置 ,快指针移动 2 个 。
  • 初始快慢指针放在一个位置 ,并开始循环移动 。
  • 如果有环 ,那么随着移动的进行 ,终有快指针经过环遇到并超过慢指针的时候 ,那么这就可以用来判断是否存在环的依据啦 。

原地移除重复元素 。这也是 LeetCode 上比较经典也比较容易的问题 。给定一个排序数组 ,要求删除其中的重复项 。同类型的还有删除给定值 。这两题在 LeetCode 的第 26 和第 27 题 :

No.26 删除排序数组中的重复项

No.27 移除元素

奇偶排序 。一个公司的面试题 ,给定一个数组 ,有奇数也有偶数 ,要通过处理将奇数放在左边 ,偶数在右边 。这个也可以通过双指针思路进行解决 。

  • 定义两个指针 ,分别指向首尾 。
  • 左边指针元素若为奇数(取模得 1)指针右移 ,直到指向第一个偶数元素 。
  • 右边指针元素若为偶数 (取模得 0)指针左移 ,直到指向第一个奇数元素 。
  • 将上述两个指针指向元素互换 。
  • 重复上述步骤 ,直到指针指向同一个元素 。

参考代码如下 :

关于双指针的应用还有很多呀 ,欢迎读者小伙伴们一起留言区补充交流 。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-11-23,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 小詹学Python 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
对象存储
对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档