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

資訊專欄INFORMATION COLUMN

四元組相加獲得target

sunsmell / 2557人閱讀

摘要:四元組相加獲得給定一個數(shù)組,選擇四個元素相加,結果為,找出所有符合的四元組。思路思路參照三元組相加獲得多一層循環(huán)即可,注意邊界檢測即可。代碼本題以及其它題目代碼地址地址

四元組相加獲得target 4Sum

給定一個數(shù)組,選擇四個元素相加,結果為target,找出所有符合的四元組。

Given an array S of n integers, are there elements a, b, c, and d in S such that a + b + c + d = target? Find all unique quadruplets in the array which gives the sum of target.

Note: The solution set must not contain duplicate triplets.

example 1

For example, given array S = [1, 0, -1, 0, -2, 2], and target = 0.

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

思路參照三元組相加獲得target

多一層循環(huán)即可,注意邊界檢測即可。

代碼
class Solution(object):
    def fourSum(self, nums, target):
        """
        :type nums: List[int]
        :type target: int
        :rtype: List[List[int]]
        """
        nums.sort()
        ret = []
        for i in range(len(nums) - 3):
            if i > 0 and nums[i] == nums[i - 1]:
                continue
            for j in range (i+1, len(nums) - 2):
                if j > i + 1 and nums[j] == nums[j - 1]:
                    continue
                head, tail = j+1, len(nums) - 1
                while head < tail:
                    if nums[i] + nums[j] + nums[head] + nums[tail] == target:
                        ret.append([nums[i], nums[j], nums[head], nums[tail]])
                        head += 1
                        tail -= 1
                        while head < tail and nums[head] == nums[head - 1]:
                            head += 1
                        while head < tail and nums[tail] == nums[tail + 1]:
                            tail -= 1
                    elif nums[i] + nums[j] + nums[head] + nums[tail] > target:
                        tail -= 1
                    else:
                        head += 1
        return ret

本題以及其它leetcode題目代碼github地址: github地址

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

轉載請注明本文地址:http://systransis.cn/yun/38666.html

相關文章

  • JS算法題之leetcode(11~20)

    摘要:給定一個整數(shù),將其轉為羅馬數(shù)字。字符數(shù)值例如,羅馬數(shù)字寫做,即為兩個并列的。通常情況下,羅馬數(shù)字中小的數(shù)字在大的數(shù)字的右邊。給定一個羅馬數(shù)字,將其轉換成整數(shù)。注意空字符串可被認為是有效字符串。 JS算法題之leetcode(11~20) showImg(https://segmentfault.com/img/bVbwmfg?w=1790&h=714);這次的十道題目都比較容易,我們簡...

    CoderDock 評論0 收藏0
  • LeetCode18.四數(shù)之和 JavaScript

    摘要:給定一個包含個整數(shù)的數(shù)組和一個目標值,判斷中是否存在四個元素,,和,使得的值與相等找出所有滿足條件且不重復的四元組。滿足要求的四元組集合為答案參考先排序第一個第二個第三個 給定一個包含 n 個整數(shù)的數(shù)組 nums 和一個目標值 target,判斷 nums 中是否存在四個元素 a,b,c 和 d ,使得 a + b + c + d 的值與 target 相等?找出所有滿足條件且不重復的...

    antyiwei 評論0 收藏0
  • 萬人千題計劃-32

    摘要:假設模式起始位置為,判斷后續(xù)序列是否滿足條件,其實只需要判斷與是否相同。如果數(shù)組中不存在至少重復次且長度為的模式,返回注意這里需要加一,否則會錯 萬人千題計劃 今...

    galois 評論0 收藏0
  • 以太坊數(shù)據(jù)結構MPT

    摘要:是以太坊存儲數(shù)據(jù)的核心數(shù)據(jù)結構,它是由和結合的一種樹形結構,理解有助于我們更好的理解以太坊的數(shù)據(jù)存儲。所以就有了樹壓縮前綴樹,后面會介紹到,也被稱為,中文名稱默克爾樹,主要用于數(shù)據(jù)集較大時的文件校驗。 ??MPT(Merkle Patricia Tries)是以太坊存儲數(shù)據(jù)的核心數(shù)據(jù)結構,它是由Merkle Tree和Patricia Tree結合的一種樹形結構,理解MPT有助于我們更...

    Honwhy 評論0 收藏0
  • 以太坊源碼分析--MPT樹

    摘要:是以太坊中存儲區(qū)塊數(shù)據(jù)的核心數(shù)據(jù)結構,它和融合一個樹形結構,理解結構對之后學習以太坊區(qū)塊以及智能合約狀態(tài)存儲結構的模塊源碼很有幫助。 MPT(Merkle Patricia Tries)是以太坊中存儲區(qū)塊數(shù)據(jù)的核心數(shù)據(jù)結構,它Merkle Tree和Patricia Tree融合一個樹形結構,理解MPT結構對之后學習以太坊區(qū)塊header以及智能合約狀態(tài)存儲結構的模塊源碼很有幫助。 首...

    roadtogeek 評論0 收藏0

發(fā)表評論

0條評論

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