• LeetCode221130_132、18. 四数之和


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

    0 <= a, b, c, d < n
    a、b、c 和 d 互不相同
    nums[a] + nums[b] + nums[c] + nums[d] == target
    你可以按 任意顺序 返回答案 。

    示例 1:

    输入:nums = [1,0,-1,0,-2,2], target = 0
    输出:[[-2,-1,1,2],[-2,0,0,2],[-1,0,0,1]]

    来源:力扣(LeetCode)
    链接:https://leetcode.cn/problems/4sum
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    题解、剪枝 当前轮最大最小与target对比进行剪枝。求和用(long)不溢出,去重注意添加索引的条件。

    1. class Solution {
    2. public List<List<Integer>> fourSum(int[] nums, int target) {
    3. List<List<Integer>> res = new ArrayList<>();
    4. if (nums.length < 4 || nums == null) return res;
    5. Arrays.sort(nums);
    6. int len = nums.length;
    7. for (int i = 0; i < len - 3; i++) {
    8. long min1 = (long) nums[i] + nums[i + 1] + nums[i + 2] + nums[i + 3];
    9. if (min1 > target) return res;
    10. long max1 = (long) nums[i] + nums[len - 1] + nums[len - 2] + nums[len - 3];
    11. if (max1 < target) continue;
    12. if (i > 0 && nums[i] == nums[i - 1]) continue;
    13. for (int j = i + 1; j < len - 2; j++) {
    14. long min2 = (long) nums[i] + nums[j] + nums[j + 1] + nums[j + 2];
    15. if (min2 > target) break;
    16. long max2 = (long) nums[i] + nums[j] + nums[len - 1] + nums[len -2];
    17. if (max2 < target) continue;
    18. if (j > i + 1 && nums[j] == nums[j - 1]) continue;
    19. int L = j + 1;
    20. int R = len - 1;
    21. while (L < R) {
    22. long sum = (long) nums[i] + nums[j] + nums[L] + nums[R];
    23. if (sum == target) {
    24. res.add(Arrays.asList(nums[i], nums[j], nums[L], nums[R]));
    25. while (L < R && nums[L] == nums[L + 1]) L++;
    26. while (L < R && nums[R] == nums[R - 1]) R--;
    27. L++;
    28. R--;
    29. } else if (sum > target) {
    30. R--;
    31. } else {
    32. L++;
    33. }
    34. }
    35. }
    36. }
    37. return res;
    38. }
    39. }

  • 相关阅读:
    微信native支付
    1、ArrayList源码解析
    Python **运算符(python**kwargs:参数解包)(kwargs:keyword arguments)
    [NAS] Synology (群晖) DSM相关服务及套件安装
    防火墙dmz实验
    PD1.4转HDMI2.0转接线拆解。
    十大创新方向发布 悬镜安全强势领跑软件供应链安全与开发安全
    Leecode33:二叉搜索树的后续遍历序列
    【Linux】 vi / vim 使用
    多亏了这份大佬整理的Java进阶笔记,让我斩获7个offer
  • 原文地址:https://blog.csdn.net/Zoro_666/article/details/128118068