首页
/
每日頭條
/
圖文
/
leetcode經典題目三數之和
leetcode經典題目三數之和
更新时间:2025-12-25 11:15:28

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
推荐阅读
iphone意外發布12.5正式版
iphone意外發布12.5正式版
就在今晚,北京時間15日淩晨1點,iPhone13系列終于要正式發布了。現在蘋果的保密水平什麼樣,懂得都懂,iPhone13其實早已沒什麼秘密可言,從外觀到配置,再到各項新功能基本早已被扒了個幹淨,唯一懸念可能就剩價格,不知道庫克又會在定價...
2025-12-25
我的世界該怎麼調模式
我的世界該怎麼調模式
我的世界該怎麼調模式?我的世界模式切換方法詳解我的世界模式怎麼切換?我是世界中有三種模式,那麼怎麼樣切換模式呢?三種模式都有哪些特點呢?生存模式主要是生存下去,生存模式開局是一無所有的,要生存下去就必須要自己去挖礦升級我的世界模式切換方法是...
2025-12-25
王建 十五夜望月
王建 十五夜望月
王建十五夜望月?中庭地白樹栖鴉,冷露無聲濕桂花今夜月明人盡望,不知秋思落誰家,今天小編就來說說關于王建十五夜望月?下面更多詳細答案一起來看看吧!王建十五夜望月中庭地白樹栖鴉,冷露無聲濕桂花。今夜月明人盡望,不知秋思落誰家。
2025-12-25
python需要學哪些知識點
python需要學哪些知識點
掌握計算機基礎知識、了解編程開發規範,你就可以開始學python了!至于計算機網絡、操作系統、組成原理等等這些,可以在你有一定編程基礎以後再進階學習,相信效果會更好。1-掌握計算機基礎知識零基礎從來沒接觸過計算機,你也不用擔心,因為如果你對...
2025-12-25
自動駕駛l2跟l3的區别
自動駕駛l2跟l3的區别
自動駕駛其實并不像有的人以為那樣:有一個機器人或者電腦模拟真人,幫你來開車,而是利用包括防碰撞、自動車距保持、車道保持等多套不同的駕駛輔助功能,讓它們相互配合,在特定路況和車況下,讓車子可以沒有人為操作和幹涉實現安全行駛。所以整合的這些輔助...
2025-12-25
Copyright 2023-2025 - www.tftnews.com All Rights Reserved