成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

leetcode15 3Sum 從數(shù)組中找到三個整數(shù),它們的和為0

Yangyang / 550人閱讀

摘要:題目要求輸入一個整數(shù)數(shù)組,從中找到所有的三個整數(shù)組成一個數(shù)組,這三個整數(shù)的和為。要求不包括重復(fù)的結(jié)果思路一無這里使用了三個指針。先對數(shù)組進行排序。

題目要求
Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0? Find all unique triplets in the array which gives the sum of zero.

Note: The solution set must not contain duplicate triplets.

For example, given array S = [-1, 0, 1, 2, -1, -4],

A solution set is:
[
  [-1, 0, 1],
  [-1, -1, 2]
]

輸入一個整數(shù)數(shù)組,從中找到所有的三個整數(shù)組成一個數(shù)組,這三個整數(shù)的和為0。要求不包括重復(fù)的結(jié)果

思路一:無hashset or hashmap

這里使用了三個指針。
先對數(shù)組進行排序。確定左側(cè)固定的指針,然后移動右側(cè)兩個直至找到三個值和為0.如果當(dāng)前三個指針的值小于0,則將中間的指針右移至下一個不同的值,如果小于0,則將最右側(cè)指針左移至下一個不重復(fù)的值。一旦右側(cè)和中間的指針重合,移動左側(cè)指針至下一個不重復(fù)的值,并且初始化中間和右側(cè)的指針

    public List> threeSum2(int[] nums) {
           List> result = new ArrayList>();
        int length = nums.length;
        if(length<3){
            return result;
        }
        Arrays.sort(nums);

        int i = 0;
        while(i0) break;
            int j = i+1;
            int k = nums.length - 1;
            while(j=0){
                    //消去右側(cè)重復(fù)的數(shù)字
                    while(nums[k--] == nums[k] && j < k);
                }
                
                //消去和當(dāng)前左指針相同的數(shù)字
                while(nums[i] == nums[++i] && i < nums.length - 2);
            }
            
        }
        return result;
    }
思路二:有hashmap/hashset

利用hashmap/hashset是為了避開重復(fù)的值,但是效率值明顯不如上一種方法高

public List> threeSum(int[] num) {
    Arrays.sort(num);
    List> list = new ArrayList>();
    HashSet> set = new HashSet>();
    for(int i=0;i l= new ArrayList();
                l.add(num[i]);
                l.add(num[j]);
                l.add(num[k]);
                if(set.add(l))
                list.add(l);
                j++;
                k--;
            }
            else if(num[i]+num[j]+num[k]<0)
            j++;
            else
            k--;
        }
    }
    return list;
}


想要了解更多開發(fā)技術(shù),面試教程以及互聯(lián)網(wǎng)公司內(nèi)推,歡迎關(guān)注我的微信公眾號!將會不定期的發(fā)放福利哦~

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/66966.html

相關(guān)文章

  • leetcode16 3Sum Closest

    摘要:返回這三個值的和。思路一三指針這里的思路和是一樣的,就是用三個指針獲得三個值并計算他們的和。 題外話 鑒于這一題的核心思路和leetcode15的思路相同,可以先寫一下15題并參考一下我之前的一篇博客 題目要求 Given an array S of n integers, find three integers in S such that the sum is closest to...

    Blackjun 評論0 收藏0
  • leetcode 15 3Sum

    摘要:要求序列不重復(fù)。這個問題比較復(fù)雜的一點是,還要處理重復(fù)的數(shù)據(jù)。為了簡化我們的操作,我們先對數(shù)組進行預(yù)排序。排序之后,對于求兩個數(shù)和的問題,可以通過和兩個指針從兩邊查找,也簡化了操作時間。解法防止重復(fù)序列 題目詳情 Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0...

    FuisonDesign 評論0 收藏0
  • leetcode494. Target Sum

    摘要:為了尋找合適的正負(fù)號賦值,我們其實可以將數(shù)組分為兩個子集,其中一個子集中的數(shù)字都被賦予了正號,而另一個子集中的數(shù)字都被賦予了負(fù)號。如果二者的和不是一個偶數(shù),就一定無法找到這樣的正負(fù)號集合使得其結(jié)果為。 題目要求 You are given a list of non-negative integers, a1, a2, ..., an, and a target, S. Now yo...

    RobinTang 評論0 收藏0
  • leetcode 16 3Sum Closest

    摘要:題目詳情給定一個整數(shù)數(shù)組,我們需要找出數(shù)組中三個元素的加和,使這個加和最接近于輸入的數(shù)值。返回這個最接近的加和。找后兩個元素的時候,使用左右指針從兩端查找。 題目詳情 Given an array S of n integers, find three integers in S such that the sum is closest to a given number, targe...

    atinosun 評論0 收藏0
  • [LintCode/LeetCode] 3Sum

    摘要:雙指針法的解法。然后用和夾逼找到使三數(shù)和為零的三數(shù)數(shù)列,放入結(jié)果數(shù)組。對于這三個數(shù),如果循環(huán)的下一個數(shù)值和當(dāng)前數(shù)值相等,就跳過以避免中有相同的解。 Problem Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0? Find all unique triplet...

    Sunxb 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<