首页
/
每日頭條
/
圖文
/
leetcode經典題目三數之和
leetcode經典題目三數之和
更新时间:2026-01-11 16:31:13

leetcode經典題目三數之和?題目來源于 LeetCode 上第 15 号問題:三數之和,下面我們就來聊聊關于leetcode經典題目三數之和?接下來我們就一起去了解一下吧!

leetcode經典題目三數之和(LeetCode第15)1

leetcode經典題目三數之和

題目來源于 LeetCode 上第 15 号問題:三數之和。

題目描述

給定一個包含 n 個整數的數組 nums,判斷 nums 中是否存在三個元素 a,b,c ,使得 a b c = 0 ?找出所有滿足條件且不重複的三元組。

題目解析

題目需要我們找出三個數且和為 0 ,那麼除了三個數全是 0 的情況之外,肯定會有負數和正數,所以一開始可以先選擇一個數,然後再去找另外兩個數,這樣隻要找到兩個數且和為第一個選擇的數的相反數就行了。也就是說需要枚舉 a 和 b ,将 c 的存入 map 即可。

需要注意的是返回的結果中,不能有有重複的結果。這樣的代碼時間複雜度是 O(n^2)。在這裡可以先将原數組進行排序,然後再遍曆排序後的數組,這樣就可以使用雙指針以線性時間複雜度來遍曆所有滿足題意的兩個數組合。

動畫描述

待補充

代碼實現

class Solution { public: vector<vector<int>> threeSum(vector<int>& nums) { vector<vector<int>> res; sort(nums.begin(), nums.end()); if (nums.empty() || nums.back() < 0 || nums.front() > 0) return {}; for (int k = 0; k < nums.size(); k) { if (nums[k] > 0) break; if (k > 0 && nums[k] == nums[k - 1]) continue; int target = 0 - nums[k]; int i = k 1, j = nums.size() - 1; while (i < j) { if (nums[i] nums[j] == target) { res.push_back({nums[k], nums[i], nums[j]}); while (i < j && nums[i] == nums[i 1]) i; while (i < j && nums[j] == nums[j - 1]) --j; i; --j; } else if (nums[i] nums[j] < target) i; else --j; } } return res; } };

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
pdf标記高亮怎麼改顔色(如何給PDF添加不同顔色的高亮并添加注釋)
pdf标記高亮怎麼改顔色(如何給PDF添加不同顔色的高亮并添加注釋)
  我們在閱讀PDF文件的時候,經常需要給PDF文件添加高亮來突出突出重點,有時候,不同類型的重點需要不同的顔色來添加高亮或直接添加标注,那如何給PDF添加不同顔色的高亮并添加注釋?今天小編就給大家推薦一款非常好用的PDF工具“金閃PDF編輯器”。   手機端(安卓和IOS)給PDF添加高亮并添加注釋:   第1 步:在手機上下載金閃PDF編輯器并打開,在首...
2026-01-11
怎麼修改pdf中的文字(怎麼直接修改pdf中的文字)
怎麼修改pdf中的文字(怎麼直接修改pdf中的文字)
  #頭條創作挑戰賽#   市面上各類第三方PDF編輯工具都可以實現pdf中文字的直接修改,小編這裡總結了三種常用且簡單易學的方法分别來實現,一起來學習下吧!   方法一:使用Adobe Acrobat DC打開需要修改文字的pdf文件,單擊右側的“編輯PDF”功能圖标,即可自動将pdf中文字識别為可編輯狀态,直接修改即可。   方法二:使用福昕高級PDF編...
2026-01-11
capcom 動作合集(動作天尊CAPCOM的另類屬性研究)
capcom 動作合集(動作天尊CAPCOM的另類屬性研究)
  【遊戲文化】低段位玩家,高段位視點。鑒于有朋友說上期看的不過瘾,熊叔決定加快進度,繼續推進動作天尊CAPCOM的下篇故事!      各位看官,閑話不多說,書接上回。有興趣了解上篇故事的小夥伴請點擊這裡。動作天尊CAPCOM的另類屬性研究(上篇)PS2時代十年的輝煌,也是日系廠商最後的輝煌在PS2時代,CAPCOM和其他日廠一樣,背靠大樹悠閑了一把,《鬼...
2026-01-11
steam求生之路2能氪金嗎(利益與良知的艱難選擇)
steam求生之路2能氪金嗎(利益與良知的艱難選擇)
  不知道大家還記不記得冒險解謎獨立遊戲《旁觀者》?反烏托邦題材的解謎遊戲,加上無處不在的監視與道德抉擇,選擇當好人自己就要死,當壞人卻又良心上過不去,玩過的小夥伴估計都非常印象深刻。這款備受好評的《旁觀者》官方微博宣布,《旁觀者2(Beholder 2)》的制作已經全面展開,并且遊戲已經在Steam上架,預計2018年發售,移動端也有可能跟上哦~     ...
2026-01-11
盛夏未來吳磊打碟張子楓後台(早報超有料盛夏未來張子楓吳磊CP感拉滿怒火)
盛夏未來吳磊打碟張子楓後台(早報超有料盛夏未來張子楓吳磊CP感拉滿怒火)
  新鮮資訊morning call 盡在早報超有料   新的一天,朋友們早上好呀。三伏天,伴随着偶爾的晴天與按時報道的暴雨,還是要靠空調才能“續命”。話不多說,說多了都是汗,一起來看看今天的早報吧~      預告搶鮮看丨張子楓吳磊《盛夏未來》曝新海報《怒火·重案》甄子丹謝霆鋒上演厮殺   昨日,由陳正道執導,張子楓、吳磊、郝蕾、祖峰等主演的青春電影《盛夏...
2026-01-11
Copyright 2023-2026 - www.tftnews.com All Rights Reserved