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

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
推荐阅读
盆栽金桔幾月剪枝
盆栽金桔幾月剪枝
想要盆栽金桔結滿枝,陽光、施肥和修剪很關鍵,還要注意避免這個每年臨近春節的時候,花市上的熱門植物中總是少不了金桔的身影。當人們把金燦燦的金桔買回家的時候,寄托的是一種興旺祥和,碩果累累的念想。所以說,金桔也是家庭中很受歡迎的一種植物。那麼,...
2026-01-03
糖友自測血糖分享
糖友自測血糖分享
糖友自測血糖分享?來源:武漢晚報武漢晚報訊(記者武葉通訊員劉姗姗)“老糖友”自測血糖偏高,便自行加大了胰島素注射用量,不料竟導緻低血糖昏迷,經搶救才脫險專家表示,臨床經常會遇到這樣的老人,因操作方法不當導緻測量結果“失真”,誤導用藥,下面我...
2026-01-03
廣東爬山遊記
廣東爬山遊記
廣東爬山遊記?尋找感覺象牙山村遊記,現在小編就來說說關于廣東爬山遊記?下面内容希望能幫助到你,我們來一起看看吧!廣東爬山遊記尋找感覺象牙山村遊記中國比較大的城市很多,而能讓你笑着說出這句話的地方,恐怕也隻有鐵嶺了吧。原來的行程計劃中本沒有象...
2026-01-03
淘寶差評師騙局
淘寶差評師騙局
今年是淘寶15周年。15年來,淘寶就像阿裡的一堆原火,開天辟地,不斷蔓延繁衍出新的業務生态,從即時溝通的旺旺到在線支付的支付寶,阿裡依托淘寶改變了中國人的購物文化,還有創業觀。然而,阿裡在變,變得無處不在。淘寶還是那個淘寶,魚龍混雜,敲詐不...
2026-01-03
對仁者樂山智者樂水的理解
對仁者樂山智者樂水的理解
孔夫子有句話:“仁者樂山,智者樂水。”《道德經》:“上善若水。水善利萬物而不争,處衆人所惡,故幾於道矣。居善地;心善淵,與善仁,言善信,政善治,事善能,動善時。夫惟不争,故無尤。”老子在《道德經》中也用了山和水來做比喻:第一是谷,大山之間能...
2026-01-03
Copyright 2023-2026 - www.tftnews.com All Rights Reserved