首页
/
每日頭條
/
圖文
/
leetcode經典題目三數之和
leetcode經典題目三數之和
更新时间:2026-03-03 19:10:06

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
推荐阅读
成都太古裡有多少家奢侈品店
成都太古裡有多少家奢侈品店
記者|陳奇銳編輯|樓婍沁成都的奢侈品購買力不容小觑。根據時尚行業自媒體“時尚商業Daily”,相關消息人士近日透露,位于成都遠洋太古裡的古馳門店為品牌在2021年全球銷售額最高的正價門店。成都本地奢侈品消費強勁和遊客數量增加,是驅動太古裡古...
2026-03-03
總是打噴嚏感覺屋裡有灰塵
總是打噴嚏感覺屋裡有灰塵
很多時候,我們明明把房間打掃得幹幹淨淨,看起來窗明幾淨,一塵不染。但呼吸之間還是覺得髒髒的,經常打噴嚏、咳嗽,家人過敏鼻炎也總犯,這是為什麼呢?你不知道的是,其實空氣中隐藏了數量龐大的污染物,包括灰塵顆粒、花粉、植物孢子、塵螨、煙氣、甲醛、...
2026-03-03
超員行駛隐患大僥幸心理不可有
超員行駛隐患大僥幸心理不可有
超員是嚴重交通違法行為但總有駕駛人铤而走險問起超員的理由,無非就是“順路,擠一擠很快就到了”在“擠”和“順便”的同時安全隐患也在悄悄潛伏交警蜀黍表示超員萬萬“駛”不得為切實做好高速公路交通安全管理工作,确保轄區道路安全暢通,按照交通事故預防...
2026-03-03
一組60年代兒童經典年畫珍藏版
一組60年代兒童經典年畫珍藏版
最後一張太珍貴了!看了此圖,保證生兒子!多子多孫!吉祥如意,百子千孫.........................................................................................
2026-03-03
桂花怎麼才能變成老樁
桂花怎麼才能變成老樁
常有人用山中挖下的流蘇老樁嫁接桂花,搖身一變、就成了桂花“老樁”怎樣辨認?流蘇與桂花是同科不同屬的兩種植物,不應将各自的樹齡合加計算給某一方。二者嫁接後成為同株才改稱為桂花,它們同扡插等其他繁育方法獲得的新株一樣,都是繁殖的第一步,應由此新...
2026-03-03
Copyright 2023-2026 - www.tftnews.com All Rights Reserved