栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

【LeetCode】18. 4Sum(中等难度)

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

【LeetCode】18. 4Sum(中等难度)

和15题非常非常类似


参照第15题的解法。

class Solution {
    public List> fourSum(int[] nums, int target) {
        Arrays.sort(nums);
        List> res = new linkedList<>();
        for(int i = 0; i < nums.length - 3; i++){
            if(i == 0 || (i > 0 && nums[i] != nums[i-1])){
                for(int j = i + 1; j < nums.length - 2; j++){
                    if(j == i + 1 || (nums[j] != nums[j-1])){
                        int l = j + 1, h = nums.length - 1, sum = target - nums[i] - nums[j];
                        while(l < h){
                            if(nums[l] + nums[h] == sum){
                                res.add(Arrays.asList(nums[i], nums[j], nums[l], nums[h]));
                                while(l < h && nums[l] == nums[l+1]) l++;
                                while(l < h && nums[h] == nums[h-1]) h--;
                                l++;
                                h--;
                            }else if(nums[l] + nums[h] < sum){
                                l++;
                            }else{
                                h--;
                            }
                        }
                    }
                }
            }
        }
        return res;
    }
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/317299.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号