首页
/
每日頭條
/
圖文
/
leetcode經典題目三數之和
leetcode經典題目三數之和
更新时间:2026-02-28 14:55:23

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-02-28
高分爆笑喜劇(年度爆笑喜劇回歸)
高分爆笑喜劇(年度爆笑喜劇回歸)
  來源于:黃河票務APP   三個小時笑死的年度喜劇,劇情高潮叠起、笑點密集如掃雷,屯好的成噸包袱,全場無尿點,節奏完全流暢,浪到飛起,讓你整個笑完全程,絕對值回票價!      喜劇片《糊塗戲班》最早是由英國著名小說家、戲劇家邁克爾·弗萊恩所創作的,于1982年在倫敦首演,它一問世就引起了觀衆的熱烈反應。   該劇後來多次被改編為電視劇和複排,成為倫敦西...
2026-02-28
電視台機器人(海南周刊機器人也)
電視台機器人(海南周刊機器人也)
  機器人能有多聰明?   6月13日,第二十五屆中國機器人及人工智能大賽全國總決賽在海口以線上線下結合的形式同步舉行,全國300多所高校800多支隊伍緊張對決。      機器人競技賽——仿人短跑。      機器人競技格鬥比賽。   在賽場上,格鬥機器人撞擊對抗,互相博弈,熱血沸騰;無人協同,無人機飛越障礙,穩當停駐;還有仿生賽中,機器狗奔跑跳躍,翻越障...
2026-02-28
澤塔奧特曼全新形态降臨第23彈(澤塔奧特曼第三話預告)
澤塔奧特曼全新形态降臨第23彈(澤塔奧特曼第三話預告)
  澤塔首話迎來的評價可以說是相當之高,同時澤塔奧特曼與遙輝兩人之間的互動也是讓不少粉絲印象深刻,畢竟已經很長時間沒有看到過這麼可愛的兩個人了,尤其是小聲說按一下按鈕,一下子就讓粉絲記住了這位奧特曼,不得不說奧特曼自從學會開口說話之後形象的塑造也是越來越強了。起初的時候以為圓谷會給出了第二話的追加預告,但沒有想到的是直接給出了第三話預告,什麼叫做自信,這就是...
2026-02-28
蘇聯為什麼能反攻莫斯科(損失慘重的蘇聯)
蘇聯為什麼能反攻莫斯科(損失慘重的蘇聯)
  1941年6月22日淩晨3點15分,德軍以總兵力550多萬人的空前作戰規模,在4900餘架戰機、3700輛坦克、 47000門大炮、190餘艘艦艇的配合下,對蘇聯發動了代号為“巴巴羅薩”的軍事打擊,襲擊了蘇聯西部邊境的幾個大軍區。德國空軍首先突襲了西部邊境的蘇聯空軍機場,然後大批德軍裝甲坦克集群在寬大的正面向蘇聯發起了快速攻擊,蘇軍被迫應戰……     ...
2026-02-28
Copyright 2023-2026 - www.tftnews.com All Rights Reserved