优选算法——双指针8(单调性)

本期知识点导图

1.上期参考代码

cpp 复制代码
class Solution {
public:
    vector<vector<int>> jiayou(vector<int>& nums) {
        int n = nums.size();
        sort(nums.begin(), nums.end());//排序
        vector<vector<int>> ret;
       for(int i=0;i<n;)//这里语句可以为空,for循环固定i
       {
          int left =i+1;
          int right =n-1;
          int target=-nums[i];
            //小优化
          if(nums[i]>0)//这里可以写>=0吗?
          break;
          //找两数之和
          while(left<right)
         {
            int s=nums[left]+nums[right];
           
            if(s<target) left++;
            else if(s>target)right--;
            else 
            {
            ret.push_back({nums[i],nums[left],nums[right]});
            left++;
            right--;
            while(left<right&&nums[left]==nums[left-1])left++;//去重,注意防越界
            while(left<right&&nums[right]==nums[right+1])right--;//这里判断条件要注意
            }
         }
         i++;//为什么不能在for里面自增?
         while(i<n&&nums[i]==nums[i-1]) i++;//同理去重i,注意防越界
       }
       return ret;
    }
};

新手同学,如果看了前几期博客的话,应该是有思路的,但是动手写就是很难写出来,很正常,但越是难,我们越是要对它进行脱敏,关关难过,我们关关过,练多了自然就熟练了~~

2.本期题目解析

四数之和(点击跳转)

重点:

随机数找四元组

四数之和为目标值

要去重

孩子们,熟悉的味道又来了,俄罗斯套娃,会三数之和,就一定会这道题目,至少思路上没问题。但是煮波还是将这题拿了出来,一是题目比较锻炼代码实现能力 ,作为巩固练习非常合适,二是题目中有几个要注意的点,非常阴,我想拿来折磨一下你们,嘻

3.思路讲解

3.1暴力解法

排序加穷举

  • 先用sort 接口将原数组排序

    当数组呈升序 ,方便后边的去重 操作(重复元素相邻

  • 遍历所有四元组,找到满足条件的四元组,通过push_back接口,放到ret中去

  • 不管是暴力解还是优解,都要进行去重操作

cpp 复制代码
class Solution {
public:
    vector<vector<int>> hajiminanbeilvdou(vector<int>& nums) {
        int n = nums.size();
        // 排序
        sort(nums.begin(), nums.end());
        vector<vector<int>> ret;        
        for (int i = 0; i < n - 3; i++) {
            // 去重i
            if (i > 0 && nums[i] == nums[i-1]) continue;
            for (int j = i + 1; j < n - 2; j++) {
                // 去重j:
                if (j > i + 1 && nums[j] == nums[j-1]) continue;
                for (int k = j + 1; k < n - 1; k++) {
                    // 去重k
                    if (k > j + 1 && nums[k] == nums[k-1]) continue;
                    for (int l = k + 1; l < n; l++) {
                        // 去重l:
                        if (l > k + 1 && nums[l] == nums[l-1]) continue;   
                        if (nums[i] + nums[j] + nums[k] + nums[l] == 0) {
                            ret.push_back({nums[i], nums[j], nums[k], nums[l]});
                        }
                    }
                }
            }
        }
        return ret;
    }
};

O(N^4)的复杂度必然超时

3.2双指针

思路同三数之和一样,只是多了个循环,多了个去重,多了个减法运算(算出三数之和的目标值),既然会三数之和了,那么大家可以自己去尝试把它写出来啦~~

不会三数之和的跳:

参考代码下期见

4.预告

我们双指针专题到这里就结束了,我们一共讲了8个小题目,大致能分成5种题型

大家做好复习工作哈

下期我们就要进入新的专题啦~

下期的题目是

长度最小的子数组(点击跳转)

明天见~

相关推荐
追随者永远是胜利者4 小时前
(LeetCode-Hot100)253. 会议室 II
java·算法·leetcode·go
会周易的程序员4 小时前
cNetgate物联网网关内存数据表和数据视图模块架构
c语言·c++·物联网·架构·lua·iot
Jason_Honey25 小时前
【平安Agent算法岗面试-二面】
人工智能·算法·面试
宇木灵5 小时前
C语言基础-十、文件操作
c语言·开发语言·学习
程序员酥皮蛋5 小时前
hot 100 第三十五题 35.二叉树的中序遍历
数据结构·算法·leetcode
追随者永远是胜利者5 小时前
(LeetCode-Hot100)207. 课程表
java·算法·leetcode·go
云泽8086 小时前
C++ 多态入门:虚函数、重写、虚析构及 override/final 实战指南(附腾讯面试题)
开发语言·c++
仰泳的熊猫6 小时前
题目1535:蓝桥杯算法提高VIP-最小乘积(提高型)
数据结构·c++·算法·蓝桥杯
那起舞的日子6 小时前
动态规划-Dynamic Programing-DP
算法·动态规划
闻缺陷则喜何志丹6 小时前
【前后缀分解】P9255 [PA 2022] Podwyżki|普及+
数据结构·c++·算法·前后缀分解