亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

[Leetcode] 15. 3Sum

2019-11-14 09:34:15
字體:
來源:轉載
供稿:網友

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 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] ]

思路 1. 暴力枚舉法+分類討論法。這種題直接暴力枚舉的話,時間復雜度高達O(n^3),所以我一開始對暴力枚舉加上了分類討論。三個數之和為0有以下幾種情況:

情況 負數個數 零個數 正數個數
1 2個 0個 1個
2 1個 0個 2個
3 1個 1個 1個
4 0個 3個 0個

因此,首先對輸入的數組進行“正數,零,負數”分類,然后再窮舉這四種情況的所有組合。最后發現,時間復雜度仍然接近O(n^3),這優化意義不大。

#Note: 以下兩種方法是題目“2sum”的延伸。“2sum”求的是:對于輸入的數組,求出兩數之和等于某特定值的所有組合。在這題目“3sum”中,因為題目是求a,b,c使得a+b+c=0,所以我們可以看作是求a,b使得a+b=-c。這樣其實就是窮舉版的“2sum”問題。 2. 借助hash表。對輸入的數組放入一個哈希表中,然后遍歷哈希表的每一個數a,然后調用2sum函數:新建一個用于標記的集合set,遍歷輸入數組的每一個值b(此時要去掉一個數a,因為數具有不可復用性),判斷集合set中是否存在一個數c,使得c = -a-b。如果有,則為目標答案,加到result list中;如果沒有,則把b數加入到集合set中。 這樣做的好處在于減少了一層循環,使得時間復雜度降為O(n^2),但同時空間復雜度是O(n)。另外,調用2sum函數時,也可以遍歷已建立好的hash表,可以更節省時間。不過需要注意的是要考慮[0,0,0]這種情況。 3. 雙向游標法。首先將輸入數組nums排序,然后遍歷輸入數組的每個數a作為target值,然后調用2sum函數:對于有序數組(除去數a),定義兩個指針指向首尾兩端,即,一個指向nums[0],一個指向num[len(nums)]。然后有如下三種情況: (1) 若當前和小于-a,則左指針右移; (2) 若當前和大于-a,則右指針左移; (3) 若當前和等于-a,則為目標答案。 這里排序的時間復雜度為O(nlogn),遍歷的時間復雜度為O(n^2),所以總的時間復雜度近似于O(n^2).

Solution :

方法2

# -*- coding: utf-8 -*-"""Created on Sat Feb 04 22:30:34 2017@author: liangsht"""def find2Sum(self,target,newdict): hashset = set() for item in newdict.keys(): remain = target - item if remain in hashset: if remain != item: self.myappend([-target,item,remain]) elif newdict[item] >= 2: self.myappend([-target,item,remain]) else: hashset.add(item)class Solution(object): res = [] def myappend(self,occupylist): occupylist.sort() if occupylist not in self.lll: self.res.append(occupylist) def threeSum(self, nums): self.res = [] numslen = len(nums) if numslen <= 2: return [] hashdict = dict() hashdict[int(nums[0])] = 1 for i in xrange(1, numslen): #construct a hash map for list nums if nums[i] in hashdict.keys(): hashdict[nums[i]] += 1 else: hashdict[nums[i]] = 1 for item in hashdict.keys(): if item == 0 and hashdict[item] >=3: self.myappend([0,0,0]) continue target = 0-item newdict = hashdict.copy() hashdict[item] -= 1 if hashdict[item] == 0: newdict.pop(item) find2Sum(self,target,newdict) return self.res

方法3

def threeSum(self, nums): res = [] nums.sort() for i in xrange(len(nums)-2): if i > 0 and nums[i] == nums[i-1]: continue l, r = i+1, len(nums)-1 while l < r: s = nums[i] + nums[l] + nums[r] if s < 0: l +=1 elif s > 0: r -= 1 else: res.append((nums[i], nums[l], nums[r])) while l < r and nums[l] == nums[l+1]: l += 1 while l < r and nums[r] == nums[r-1]: r -= 1 l += 1; r -= 1 return res

ref: 1. CSDN bolg 2. leetcode discussion


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩精品一区二区视频| 中文字幕久热精品在线视频| 2019av中文字幕| 在线精品国产成人综合| 久久久精品视频在线观看| 欧美一级视频免费在线观看| 国产欧美一区二区白浆黑人| 亚洲成人999| 最新国产成人av网站网址麻豆| 国内精品免费午夜毛片| 欧美亚洲伦理www| 国产精品日日摸夜夜添夜夜av| 国色天香2019中文字幕在线观看| 81精品国产乱码久久久久久| 欧美精品一本久久男人的天堂| 国产精品久久久久久久av电影| 国产一区二区三区视频| 久久精品视频免费播放| 伊人亚洲福利一区二区三区| 国产精品久久久久久久久久久久久久| 亚洲精品电影网在线观看| 欧美性生交大片免网| 国产精品你懂得| 久久伊人精品天天| 亚洲精品第一国产综合精品| 久久99久国产精品黄毛片入口| 精品久久久久久久久中文字幕| 午夜精品一区二区三区在线播放| 伊人伊成久久人综合网站| 亚洲欧美日韩国产中文专区| 国产a∨精品一区二区三区不卡| 亚洲精品99久久久久中文字幕| 青青在线视频一区二区三区| 日本精品视频在线播放| 国产xxx69麻豆国语对白| 一本大道久久加勒比香蕉| 久久777国产线看观看精品| 国产香蕉精品视频一区二区三区| 久久综合伊人77777尤物| 九九久久久久久久久激情| 热久久免费国产视频| 全色精品综合影院| 亚洲欧美国产精品专区久久| 日韩电影大全免费观看2023年上| 国产精品香蕉在线观看| 日韩欧美综合在线视频| 日本久久久久亚洲中字幕| 中文字幕精品在线| 亚洲精品网站在线播放gif| 91久久夜色精品国产网站| 欧美日韩国产一区中文午夜| 日韩欧美福利视频| 久久久www成人免费精品| 久久精品成人欧美大片| 成人精品aaaa网站| 亚洲视频欧洲视频| 国产伦精品免费视频| 欧美另类69精品久久久久9999| 亚洲精品国产精品乱码不99按摩| 日本三级韩国三级久久| 91国内揄拍国内精品对白| 午夜精品三级视频福利| 久久久久久久久久久免费精品| 欧美亚洲午夜视频在线观看| 美日韩精品免费视频| 国产精品日韩电影| 欧美激情乱人伦一区| 欧美一级电影免费在线观看| 亚洲国产成人精品久久| 日韩视频免费中文字幕| 日韩av中文字幕在线免费观看| 在线观看成人黄色| 亚洲精品综合精品自拍| 国产精品丝袜一区二区三区| 91大神福利视频在线| 国产精品一二三视频| 亚洲专区国产精品| 国产精品久久久久久久久久久久| 欧美成人四级hd版| 日本精品一区二区三区在线| 欧美一区二区大胆人体摄影专业网站| 亚洲欧美在线x视频| 国产精品欧美一区二区| 久久精品亚洲国产| 高清在线视频日韩欧美| 亚洲国产成人精品久久久国产成人一区| 97人人做人人爱| 一本一道久久a久久精品逆3p| 亚洲欧美日韩中文在线制服| 久久精品99久久香蕉国产色戒| 91成品人片a无限观看| 这里只有精品久久| 久久99热这里只有精品国产| 欧美在线视频网站| 欧美乱大交xxxxx| 亚洲aⅴ男人的天堂在线观看| 精品视频—区二区三区免费| 国产精品久久久久久久久久久久久| 日韩av在线最新| 国产精品综合不卡av| 精品国产拍在线观看| 国产97在线视频| 精品国产拍在线观看| 久99九色视频在线观看| 国产成人精品免高潮费视频| 亚洲精品久久久久中文字幕欢迎你| www.日韩免费| 久久精品视频播放| 欧美国产日韩一区二区| 亚洲美女av在线| 国产亚洲日本欧美韩国| 欧美极品在线播放| 国产精品久久久一区| 久久综合伊人77777尤物| 高清欧美电影在线| 国产精品成人免费电影| 九九热这里只有精品6| 国产精品专区第二| 久热精品视频在线| 精品欧美国产一区二区三区| 狠狠综合久久av一区二区小说| 日本伊人精品一区二区三区介绍| 日韩av一区二区在线观看| 青草青草久热精品视频在线网站| 亚洲成人网av| 精品日本美女福利在线观看| 亚洲国产精品成人精品| 国产欧美亚洲精品| 日韩高清中文字幕| 国产一区二区欧美日韩| 欧美激情在线观看| 91干在线观看| 91香蕉嫩草神马影院在线观看| 在线观看欧美视频| 久久男人av资源网站| 中文字幕亚洲二区| 国产成人啪精品视频免费网| 国产精品免费看久久久香蕉| 成人写真视频福利网| 激情av一区二区| 国产亚洲精品一区二555| 国产欧美日韩亚洲精品| 日韩精品免费综合视频在线播放| 中文字幕国产精品久久| 96精品久久久久中文字幕| 亚洲精品小视频在线观看| 国产精品999999| 国产精品美女久久久久av超清| 亚洲国产天堂久久综合| 97超视频免费观看| 欧美性xxxx极品高清hd直播| 91国产美女在线观看| 国产成人高潮免费观看精品| 欧美影院在线播放| 日韩精品视频在线| 久久久久成人精品| 久久综合伊人77777蜜臀| 九九精品在线观看| 欧洲美女7788成人免费视频| 久久噜噜噜精品国产亚洲综合| 国产亚洲精品久久久久动| 午夜精品久久久久久久99热浪潮| 92福利视频午夜1000合集在线观看| 91av中文字幕|