[C++ leetcode] 双指针(主题结束)
最编程
2024-03-30 10:20:23
...
画图 和 文字 分析
这道题和 两数之和等于一个值 大体思路是一样的,都是 排序 + 双指针思想
排完序后,我们定义三个指针,一个指向最后一个元素的位置,一个指向首元素的位置,另一个首元素的后一个位置
举例:
输入: [-1,0,1,2,-1,-4]
输出:[[-1,-1,2],[-1,0,1]]
先固定 k不动
- 如果三者指向的值相加为 0 ,则记录数据 ,再 j++ , k--
- 如果三者指向的值 < 0 ,则 j++
- 如果三者指向的值 > 0 ,则 k--
当 i >= j (结束里层循环)
再 i++ , j = i + 1 , k = n - 1
直到 i + 1 >= k (外层循环)
做到以上,只能说完成了完成了不漏掉每一种情况,但现在还有去重的关键一步
去重需要我们在前面的基础上做更改:
第一种情况:
走完上面的步骤 :
判断现在 j 所指的内容 和 j - 1 所指内容是否相同,直到不相同为止(这里需要一个循环,此时要么,j 指向一个不和之前相重复的数,要么越界)
判断 k 同理
上面是里层循环的去重,外层循环也可以去重
当结束里层循环,完成后面的步骤 :
判断 i 所指向的内容 和 i - 1所指向的内容是否相同,直到不相同为止
注意:
去重的时候,因为循环的缘故,一定要防止越界
上一篇: 编写弧插值算法程序
下一篇: 请不要迷失在 "微服务 "的*中!