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重叠相等。
注意:因为题目中不能出现重复的选项,所以每次移动遍历时,如果后一个数和前一个数相等,则要直接跳过个数,遍历下一个,直到不重复为止
代码: