LeetCode--18.四数之和

解题思路:

1.获取信息:

(1)要求:从数组找四个位置互不不同的四个数,它们的和为目标值,就存储下来,直到返回所有互不相同的四个数组合的集合

(2)可以按任意顺序返回答案

2.分析题目:

跟第15题的三数之和差不多,这道题是求四数之和

我们可以借用分治法的思想来想一下,就是拆分问题,我们固定一个数的取值,那么就是求剩下的三个数的和,即三数之和,这样问题就得到了拆分

如果你没有做过15题三数之和就来做这道题,我建议还是从简单的入手,所以这里我就不讲解15题三数之和了,你可以看一下我之前的讲解

3.示例查验:没什么补充的

4.尝试编写代码:

这里提供一种解法

思路:我分析题目环节已经提过了,不再说了

以下是完整代码

cpp 复制代码
class Solution {
public:
    vector<vector<int>> fourSum(vector<int>& nums, int target) {
        vector<vector<int>>res;//用来储存结果的容器
        int border=nums.size();//nums中元素的数量
        sort(nums.begin(),nums.end());//对nums进行排序
        for(int i=0;i<border;i++){//这就是一开始说的,先固定一个数的取值
            if(i>0&&nums[i]==nums[i-1])continue;//去重,防止超出内存
            for(int j=i+1;j<border;j++){//取第二个数的值
                if(j>i+1&&nums[j]==nums[j-1])continue;//去重
                int begin=j+1;//下面就是动态规划了,我15题的时候讲解过,就不说了
                int end=border-1;
                long sum1=nums[i]+nums[j];
                while(begin<end){
                    long sum2=nums[begin]+nums[end];
                    if(sum1+sum2==target){
                        res.push_back({nums[i],nums[j],nums[begin],nums[end]});
                        begin++;
                        while(begin<border&&nums[begin]==nums[begin-1])begin++;
                        end--;
                        while(end>=0&&nums[end]==nums[end+1])end--;
                    }
                    else if(sum1+sum2<target)begin++;
                    else if(sum1+sum2>target)end--;
                }
            }
        }
        return res;
    }
};

好吧,还是提一嘴,纸上得来终觉浅,绝知此事要躬行

相关推荐
美式请加冰2 分钟前
子序列问题
数据结构·算法·leetcode
DeniuHe3 分钟前
线性回归与逻辑回归:同为凸函数,为何一个有解析解、一个没有?
算法·机器学习·逻辑回归
披着羊皮不是狼7 分钟前
基于CNN的图像检测算法
人工智能·算法·cnn
程序员小崔日记7 分钟前
我参加了第十七届蓝桥杯 Java B 组省赛,这套题你能撑到第几题?
java·算法·蓝桥杯大赛
6Hzlia28 分钟前
【Hot 100 刷题计划】 LeetCode 1143. 最长公共子序列 | C++ 二维DP 与 哨兵技巧
c++·算法·leetcode
Allen_LVyingbo37 分钟前
《狄拉克符号法50讲》习题与解析(下)
算法·决策树·机器学习·健康医疗·量子计算
豆沙糕37 分钟前
大模型面试高频题:请详细讲解检索中的BM25算法
人工智能·算法
不才小强38 分钟前
查找算法详解:二分查找
数据结构·算法
君义_noip41 分钟前
信息学奥赛一本通 4164:【GESP2512七级】学习小组 | 洛谷 P14922 [GESP202512 七级] 学习小组
学习·算法·动态规划·gesp·信息学奥赛
MicroTech202542 分钟前
微算法科技(NASDAQ :MLGO)面向区块链的系统的高效反量子晶格盲签名技术
科技·算法·区块链