​leetcode算法题第18题:四数之和​

leetcode算法题第18题:四数之和


题目:

给你一个由 n 个整数组成的数组 nums ,和一个目标值 target 。请你找出并返回满足下述全部条件且不重复的四元组 [nums[a], nums[b], nums[c], nums[d]] (若两个四元组元素一一对应,则认为两个四元组重复):

1. 0 <= a, b, c, d < n
2. a、b、c 和 d 互不相同
3. nums[a] + nums[b] + nums[c] + nums[d] == target

你可以按 任意顺序 返回答案 。

 


解题思路:排序+双指针

和三数之和一样,四数之和只是嵌套了两重循环,然后又用双指针不断更新四数之和的大小,具体做法 如下:

1.给数组排序,从小到大排序

2.先套用第一层循环i从0遍历到倒数第三个数,要先判断如果三个最小数都大于tagat,则返回空集合,如果三个最大的数都小于tagat,则i向右移动一位

3.再套用第二层循环j从i+1遍历到倒数第二个数,也要先判断三个最小值大于tagat,则结束第二层循环,执行第一层循环,如果三个最大值小于tagat,则j直接向右移动一位

4.在两重循环中,建立双指针left和right,left的初始位置为j+1向右遍历,right的位置则从最后一位向左遍历,每次判断四个数的和与tagat的大小,如果相等则添加进设定好的空列表,且此时left要向右移动一位,right则要向左移动一位;如果此时四个数的和大于tagat,则right向左移动一位;小于tagat,则left向右移动一位。直到left和right重叠相等。

注意:因为题目中不能出现重复的选项,所以每次移动遍历时,如果后一个数和前一个数相等,则要直接跳过个数,遍历下一个,直到不重复为止


代码:

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值