15. 3Sum

public class Solution {
    public List<List<Integer>> threeSum(int[] nums) {
        Arrays.sort(nums);
        List<List<Integer>> res=new ArrayList<>();
        for(int i=0;i<nums.length-2;i++){
            if(i==0||(i>0&&nums[i]!=nums[i-1])){
                int lo=i+1,hi=nums.length-1,sum=0-nums[i];
                while(lo<hi){
                    if(nums[lo]+nums[hi]==sum){
                        res.add(Arrays.asList(nums[i],nums[lo],nums[hi]));
                        while(lo<hi&&nums[lo]==nums[lo+1]) lo++;
                        while(lo<hi&&nums[hi]==nums[hi-1]) hi--;
                        lo++;hi--;
                    }else if(nums[lo]+nums[hi]<sum) lo++;
                    else hi--;
                }
            }
        }
        return res;
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 注意要跳过重复。把每个element 看成三个数中的一个,然后在这个数后面剩余的数里,从最大和最小的数开始做2sum.
    沉睡至夏阅读 1,020评论 0 0
  • Medium刷狗家题库看到的类似的,这个题里面去duplicates的地方值得好好想一想。 为什么我们只在if (...
    greatseniorsde阅读 962评论 0 0
  • 题目 给出一个有n个整数的数组S,在S中找到三个整数a, b, c,找到所有使得a + b + c = 0的三元组...
    六尺帐篷阅读 1,371评论 0 1
  • 题目描述:给定一个有n个整数的数组S,找到其中所有由三个数a、b、c组成,使得a + b + c = 0的三元组。...
    Nautilus1阅读 656评论 0 0
  • 01.多年前的疑问 昨晚一老同学在微信上跟我回首当年的友情。回忆起当年,他号称班级的“数学王子”,几乎没有他解不开...
    淡之阅读 2,688评论 2 15