上海古都建筑设计集团,上海办公室装修设计公司,上海装修公司高质量的内容分享社区,上海装修公司我们不是内容生产者,我们只是上海办公室装修设计公司内容的搬运工平台

力扣hot100 三数之和 双指针 细节去重

guduadmin271月前

Problem: 15. 三数之和

力扣hot100 三数之和 双指针 细节去重,在这里插入图片描述,第1张

文章目录

  • 思路
  • Code

    思路

    👨‍🏫 参考

    力扣hot100 三数之和 双指针 细节去重,在这里插入图片描述,第2张

    Code

    ⏰ 时间复杂度: O ( n 2 ) O(n^2) O(n2)

    🌎 空间复杂度: O ( 1 ) O(1) O(1)

    class Solution {
     	public List> threeSum(int[] nums)
    	{
    		List> res = new ArrayList<>();
    		int len = nums.length;
    		if (len < 3)
    			return res;
    		Arrays.sort(nums);// 升序排序
    		for (int i = 0; i < len; i++)// i选一个数(三个数中最小的数)
    		{
    			if (nums[i] > 0)// 最小数已经 > 0,和不可能 == 0
    				break;
    			// 当前数和前一个数相同,去重
    			if (i > 0 && nums[i] == nums[i - 1])
    				continue;
    			int l = i + 1;// 选取第二个数(中间的数)
    			int r = len - 1;// 选取第三个数(最大的数)
    			while (l < r)
    			{
    				int sum = nums[i] + nums[l] + nums[r];
    				if (sum == 0)
    				{
    					res.add(Arrays.asList(nums[i], nums[l], nums[r]));
    //					 去重 l 和 r 的数
    //					跳过重复的值,避免重复解
    //					例:[0,-2,-2,-1,1,2,2]  中的 -2 -2 2 2 就需要去重
    					while (l < r && nums[l] == nums[l + 1])
    						l++;
    					while (l < r && nums[r] == nums[r - 1])
    						r--;
    //					走到这,l 是连续相同段的最后一个,r 是连续相同段的第一个
    //					再跳一次,把 nums[l] nums[r] 跳过
    					l++;
    					r--;
    				} else if (sum < 0)// 左边的值 调大一点
    					l++;
    				else if (sum > 0)// 右边的值 调小一点
    					r--;
    			}
    		}
    		return res;
    	}
    }
    

网友评论

搜索
最新文章
热门文章
热门标签
 
 周公解梦梦见动物  中年女人梦见自己哭得很伤心  梦见大火烧房子是什么征兆