首页
/
每日頭條
/
圖文
/
leetcode經典題目三數之和
leetcode經典題目三數之和
更新时间:2025-12-14 14:01:39

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
推荐阅读
白細胞低為什麼喝五紅湯
白細胞低為什麼喝五紅湯
白細胞低為什麼喝五紅湯?五紅湯,相信所有姐妹都不陌生,它是一道赫赫有名的食療方,能夠補氣養血、升高白細胞、減輕化療副反應然而,依然有許多人不了解五紅湯的制作方法以及食用過程中的注意事項,在此,互助君彙總了大家常見的問題作出相應的解答,提供五...
2025-12-14
實盤和虛盤哪個受歡迎
實盤和虛盤哪個受歡迎
1、蠱惑盤從字面意思理解就是非合理的盤口,對陣雙方實力差距大,盤口不合理但是結果又是正路稱之為蠱惑盤,其目的在于誤導彩民,謀求最大的利潤。2、無論菠菜公司怎樣操盤其最終結果隻有三個勝平負,亞盤則各有50%的概率,其操盤手法大體分為三種:誘盤...
2025-12-14
出國留學聯系導師發郵件的内容
出國留學聯系導師發郵件的内容
當你有一件事不得不通知你的教授時,你戰戰兢兢打開郵箱,發現自己一個字也打不出來……就算熬到天黑寫完一篇郵件也不敢堅定地摁下發送鍵,這是你的真實寫照嗎?在留學期間,給導師發送郵件可謂是人生大事,一封郵件就能決定老師對你的印象。掌握嚴格的郵件格...
2025-12-14
長城c50鑰匙怎麼拆開
長城c50鑰匙怎麼拆開
前幾天看到朋友的鑰匙殼太破了,就說我幫你更換一個吧,這哥們手也太快了,立刻從某寶買了一個,到貨也挺快的,正好今天有點時間,下手開整,順便把電池換了,以前據說原車的鑰匙,電池是松下的,但這次打開以後,應該不是松下,換殼也沒有什麼竅門,最主要的...
2025-12-14
凡事靠自己的人是什麼樣的人
凡事靠自己的人是什麼樣的人
拿破侖說:“人多不足以依賴,要生存隻有靠自己”不要把任何的安全感、快樂寄托在别人身上,凡事都是靠自己得來的。人要逼迫自己,不要讓别人來要求你。路好不好走,腳知道;人是苦是累,隻有自己清楚。什麼事情都要學會獨自面對,摔倒了就自己爬起來。沒有人...
2025-12-14
Copyright 2023-2025 - www.tftnews.com All Rights Reserved