首页
/
每日頭條
/
圖文
/
leetcode經典題目三數之和
leetcode經典題目三數之和
更新时间:2026-06-23 22:12:56

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
推荐阅读
猜畫小歌全關卡
猜畫小歌全關卡
猜畫小歌全關卡?來源:北京晨報“靈魂畫手出沒”、“幼兒園水平讓人見笑了”……一款單一色彩、簡單線條、令腦洞大開的“猜畫小歌”小程序一上線,就迅速刷爆了朋友圈這款由谷歌中國研發的首款小程序,采用了“人類畫畫AI猜題”的模式,讓不少用戶樂此不疲...
2026-06-23
雨巷邂逅的故事
雨巷邂逅的故事
櫻木上的綠葉都已經長得有半個巴掌大了,春天似乎就這樣被忘卻了,像沒有人再擡頭去看的櫻花樹,沒有人再駐足拍照的櫻花道一般。東京的花還是依然開着,沒了櫻花,杜鵑開了,紫藤開了,充滿了舊時味道的後巷,沒有幾個人走過。藏在背後的街巷從日暮裡到上野的...
2026-06-23
東莞被騙的人員
東莞被騙的人員
警情通報2022年5月12日,南城縣建昌鎮的陳某(無業,未安裝“國家反詐中心”app)在淘寶上看到招聘兼職客服的信息後與對方取得了聯系方式,對方以淘寶客服上崗前需要培訓為由,讓陳某在培訓期間下載“新浪航空”(非正規軟件)進行虛假購買火車票的...
2026-06-23
開關接線圖大全簡單又實用
開關接線圖大全簡單又實用
最全電路圖與接線圖大全:開關、插座、二次回路圖,您一定用得上!趕快收藏吧!二次回路圖猜你喜歡接近開關接線圖接線必看值得收藏!基本照明電路及安裝、日光燈工作原理、電表接線圖,
2026-06-23
兄弟你這是遇到什麼事了嗎
兄弟你這是遇到什麼事了嗎
兄弟你這是遇到什麼事了嗎?最近工作上繁忙,已經幾個月沒有聯系我的這兩個兄弟了,現在很是想念我們從畢業到現在以來已經3年沒有見過面了最後的一次見面是我送他們上公交車的那一刻吧就連最後的三人散夥飯我都沒來得及參加,接下來我們就來聊聊關于兄弟你這...
2026-06-23
Copyright 2023-2026 - www.tftnews.com All Rights Reserved