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

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-03-05
除泰山外唯一的岱廟
除泰山外唯一的岱廟
明代禦史方嶽,出任泰州通判期間,興建浴沂亭,移建狀元坊;他登上泰山“起雲樓”,距城百裡舉在目前,西園全景盡收眼底,詩曰:泰州無泰山,飛來奠茲土;淩雲入青霄,秀色貫古今。乘風一登之,去天如尺五;忽聞弦誦聲,仿佛過齊魯。泰州泰山,雖隻是個大土墩...
2026-03-05
鑄鐵和什麼材質焊接強度高
鑄鐵和什麼材質焊接強度高
鑄鐵的焊接性很差,鑄鐵與鋼焊接,主要問題在鑄鐵一側,其焊接性和焊接工藝主要考慮鑄鐵的焊接特點,而鋼一側幾乎可不考慮。根據鑄鐵與鋼的化學成分、填充金屬類型、接頭形式和結構強度要求等選擇合适的焊接方法,鑄鐵結構與鋼的焊接,在生産中主要是各種鋼與...
2026-03-05
天機老人仙逝
天機老人仙逝
#我在頭條搞創作第二期#《多情劍客無情劍》是古龍先生的巅峰之作,也是一鍋粥最喜歡讀的小說之一,因此之前特意寫了兩個專欄文章,可是覺得還是不夠,因此又追加了第三個專欄,希望志同道合的朋友們可以喜歡,好了繼續本篇的話題:天機老人本可全身而退,為...
2026-03-05
十維宇宙最簡單的解釋
十維宇宙最簡單的解釋
天文學自古有之,從天文觀測開始,就與計算密不可分。我國元代天文學家,數學家郭守敬計算了一個地球年為365.2425天,這個結果與現代天文學測算僅相差26秒,在那個僅靠肉眼觀測和算籌計算的時代就可以得到這樣的結果,真是讓人歎為觀止!我國古代著...
2026-03-05
Copyright 2023-2026 - www.tftnews.com All Rights Reserved