• 双指针法 ( 三数之和 )


    题目  :给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i != ji != k 且 j != k ,同时还满足 nums[i] + nums[j] + nums[k] == 0 。请

    你返回所有和为 0 且不重复的三元组。

    注意:答案中不可以包含重复的三元组

    在解决这一问题中,我们需要用到相向双指针。

    首先需要对数组nums 排好序,便于之后的各种操作。

    从数组第一个数num[now] 开始向后遍历, 如果now now+1 now+2 三个数和大于0,在这种情况下,当前剩下的最小的三个数和仍大于0,那么便没有能使之后的数的和都大于0,结束循环;同样,如果now end end-1 三个数的和小于0,在这种情况下,当前数 与剩下的最大的两个数和仍小于0,那么便没有能使之后的数的和都小于0,now++,进行下一次判断;如果num[now] 与上一个数相同,now++,进行下一次判断。 将数组排序好的好处之一便在此。需要注意的是,now 在整个循环中应当小于 size - 2 ,因为最少应剩下三个数。

    在有一个符合上述条件的now 时:

    1. while (next < last) {
    2. if (nums[now] + nums[next] + nums[last] < 0)
    3. next++;
    4. else if (nums[now] + nums[next] + nums[last] > 0)
    5. last--;
    6. else {//针对每一个不同的新的数,找出不同的两个数,使三数的和为0
    7. vv.push_back({ nums[now] ,nums[next], nums[last] });//
    8. next++;
    9. last--;
    10. while (next <= end && nums[next] == nums[next - 1])//三数等于0后,判断next end之后的数是否分别与它们相同
    11. next++;
    12. while (last >= 0 && nums[last] == nums[last + 1])
    13. last--;
    14. }
    15. }

    1. class Solution {
    2. public:
    3. vectorint>> threeSum(vector<int>& nums) {
    4. vectorint>> vv;
    5. sort(nums.begin(),nums.end());
    6. int now = 0;
    7. while (now < nums.size() - 2) {
    8. int end = nums.size() - 1;
    9. if (now != 0 && nums[now] == nums[now - 1])
    10. {
    11. now++;
    12. continue;
    13. }
    14. if (nums[now] + nums[now + 1] + nums[now + 2] > 0)
    15. break;
    16. if (nums[now] + nums[end] + nums[end - 1] < 0)
    17. {
    18. now++;
    19. continue;
    20. }
    21. int next = now + 1;
    22. int last = end;
    23. while (next < last) {
    24. if (nums[now] + nums[next] + nums[last] < 0)
    25. next++;
    26. else if (nums[now] + nums[next] + nums[last] > 0)
    27. last--;
    28. else {//针对每一个不同的新的数,找出不同的两个数,使三数的和为0
    29. vv.push_back({ nums[now] ,nums[next], nums[last] });//
    30. next++;
    31. last--;
    32. while (next <= end && nums[next] == nums[next - 1])//三数等于0后,判断next end之后的数是否分别与它们相同
    33. next++;
    34. while (last >= 0 && nums[last] == nums[last + 1])
    35. last--;
    36. }
    37. }
    38. now++;
    39. }
    40. return vv;
    41. }
    42. };

  • 相关阅读:
    北斗GPS卫星时钟同步服务器在银行数据机房应用
    python库安装中Microsoft Visual C++ is required解决方法
    2022年竞赛打榜,神经网络还是干不过树模型??
    js获取Element元素的常用方法
    Mysql语句中select、where、groupby、having。。顺序
    不可错过的效能利器「GitHub 热点速览 v.22.39」
    AutoJs学习-MC我的世界自动钓鱼
    开源博客项目Blog .NET Core源码学习(23:App.Hosting项目结构分析-11)
    Prometheus字段解析
    【博客485】prometheus-----为什么prometheus与alertmanager之间要用full mesh,不能load balance
  • 原文地址:https://blog.csdn.net/2302_80190174/article/details/139393575