首页
/
每日頭條
/
圖文
/
leetcode經典題目三數之和
leetcode經典題目三數之和
更新时间:2026-03-18 06:24:01

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
推荐阅读
世界五大故宮是哪五座
世界五大故宮是哪五座
今年的疫情導緻人們無法像往年一樣正常出遊,許多景點、古迹和知名建築都顯得十分冷清,MSN網站在12月13日整理了一組世界著名的宮殿照片,帶大家在年底時去雲遊一番,稍微補足一下無法出行的遺憾:1420年建成,600歲的故宮是世界最大的宮殿群,...
2026-03-18
夢幻西遊龍宮流派怎麼點
夢幻西遊龍宮流派怎麼點
遊戲的意義就在于它能夠給人帶來快樂,如果過多的摻雜其他的東西就失去了其本身的意義,大家好,我是小三,每天給大家分享遊戲中的八卦趣事。在夢幻中鑒定裝備的時候是有可能會出現藍字效果的,這裡的藍字效果正常的情況下會是特技或者特效的一種,防具位置的...
2026-03-18
奧運會吉祥物曆年
奧運會吉祥物曆年
裡約奧組委23日公布了2016年裡約奧運會和殘奧會吉祥物,兩個吉祥物分别代表了巴西的動物和植物,體現出桑巴國度的熱情與奔放。裡約奧運會官網貼出了這兩個吉祥物的照片,他們介于卡通和現實之間,融合了巴西各種流行文化,同時又擁有動畫和電子遊戲的元...
2026-03-18
羊絨衫如何自己清洗
羊絨衫如何自己清洗
現今,人們對于時裝不再隻是追求款式,愈來愈注重面料,對于衣物,尤其是昂貴又備受人們青睐的羊絨衫的專業護理需求也日益上升。當我們擁有一件心愛的羊絨衫後,一定會很擔心羊絨衫的洗護問題,一方面,羊絨衫比較重,洗滌比較困難;另一方面,羊絨衫洗滌時,...
2026-03-18
ai圖形變換之旋轉
ai圖形變換之旋轉
今天要學習的是運用變化工具來變化圖形1.窗口—變換2.選中頁面上的圖形進行變化操作首先看一下x軸,x軸主要是用來圖形的水平位置把參照點選為左下角點看一下改變x軸數值發生的變化把x軸數值設置為零y軸用來設置圖形垂直的一個位置把y軸數值設置為零...
2026-03-18
Copyright 2023-2026 - www.tftnews.com All Rights Reserved