LeetCode 熱題100 15. 三數之和

LeetCode 熱題100 | 15. 三數之和

大家好,今天我們來解決一道經典的算法題——三數之和。這道題在 LeetCode 上被標記為中等難度,要求我們從一個整數數組中找到所有不重復的三元組,使得三元組的和為 0。下面我將詳細講解解題思路,并附上 Python 代碼實現。


題目描述

給定一個整數數組 nums,判斷是否存在三元組 [nums[i], nums[j], nums[k]] 滿足 i != ji != kj != k,同時還滿足 nums[i] + nums[j] + nums[k] == 0。請你返回所有和為 0 且不重復的三元組。

示例:

輸入:nums = [-1,0,1,2,-1,-4]
輸出:[[-1,-1,2],[-1,0,1]]

解題思路

這道題的核心是找到所有滿足條件的三元組,同時避免重復。我們可以通過排序數組和雙指針法來高效地解決這個問題。

核心思想
  1. 排序數組

    • 將數組排序,方便后續使用雙指針法。
  2. 遍歷數組

    • 固定一個數 nums[i],然后在剩下的數組中使用雙指針法尋找兩個數 nums[left]nums[right],使得 nums[i] + nums[left] + nums[right] == 0
  3. 雙指針法

    • 初始化 left = i + 1right = len(nums) - 1
    • 如果 nums[i] + nums[left] + nums[right] < 0,則 left 右移。
    • 如果 nums[i] + nums[left] + nums[right] > 0,則 right 左移。
    • 如果 nums[i] + nums[left] + nums[right] == 0,則找到一個三元組,記錄下來,并跳過重復的元素。
  4. 去重

    • 在遍歷過程中,跳過重復的 nums[i]nums[left]nums[right],避免重復的三元組。

代碼實現

def threeSum(nums):""":type nums: List[int]:rtype: List[List[int]]"""nums.sort()  # 排序數組result = []  # 存儲結果for i in range(len(nums) - 2):  # 遍歷數組,固定 nums[i]if i > 0 and nums[i] == nums[i - 1]:  # 跳過重復的 nums[i]continueleft, right = i + 1, len(nums) - 1  # 初始化雙指針while left < right:total = nums[i] + nums[left] + nums[right]  # 計算三數之和if total < 0:left += 1  # 和小于 0,左指針右移elif total > 0:right -= 1  # 和大于 0,右指針左移else:result.append([nums[i], nums[left], nums[right]])  # 找到一個三元組# 跳過重復的 nums[left] 和 nums[right]while left < right and nums[left] == nums[left + 1]:left += 1while left < right and nums[right] == nums[right - 1]:right -= 1left += 1right -= 1return result

代碼解析

  1. 排序數組

    • 將數組排序,方便后續使用雙指針法。
  2. 遍歷數組

    • 固定一個數 nums[i],然后在剩下的數組中使用雙指針法尋找兩個數 nums[left]nums[right]
  3. 雙指針法

    • 初始化 left = i + 1right = len(nums) - 1
    • 根據三數之和的大小,移動 leftright 指針。
  4. 去重

    • 在遍歷過程中,跳過重復的 nums[i]nums[left]nums[right],避免重復的三元組。

復雜度分析

  • 時間復雜度:O(n2),其中 n 是數組的長度。排序的時間復雜度為 O(n log n),雙指針法的時間復雜度為 O(n2)。
  • 空間復雜度:O(1),只使用了常數個額外空間。

示例運行

示例 1
# 輸入:nums = [-1,0,1,2,-1,-4]
nums = [-1, 0, 1, 2, -1, -4]
print(threeSum(nums))  # 輸出: [[-1, -1, 2], [-1, 0, 1]]
示例 2
# 輸入:nums = [0,1,1]
nums = [0, 1, 1]
print(threeSum(nums))  # 輸出: []
示例 3
# 輸入:nums = [0,0,0]
nums = [0, 0, 0]
print(threeSum(nums))  # 輸出: [[0, 0, 0]]

總結

通過排序數組和雙指針法,我們可以高效地找到所有滿足條件的三元組,并避免重復。這種方法的時間復雜度為 O(n2),能夠處理較大的輸入規模。希望這篇題解對你有幫助!如果還有其他問題,歡迎繼續提問!

關注我,獲取更多算法題解和編程技巧!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/71828.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/71828.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/71828.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

基因組組裝中的術語1——from HGP

Initial sequencing and analysis of the human genome | Nature 1&#xff0c;分層鳥槍法測序hierarchical shotgun sequencing

安全開發-環境選擇

文章目錄 個人心得虛擬機選擇ubuntu 22.04python環境選擇conda下載使用&#xff1a; 個人心得 在做開發時配置一個專門的環境可以使我們在開發中的效率顯著提升&#xff0c;可以避免掉很多環境沖突的報錯。尤其是python各種版本沖突&#xff0c;還有做滲透工具不要選擇windows…

數字體驗驅動用戶參與增效路徑

內容概要 在數字化轉型深化的當下&#xff0c;數字內容體驗已成為企業與用戶建立深度連接的核心切入點。通過個性化推薦引擎與智能數據分析系統的協同運作&#xff0c;企業能夠實時捕捉用戶行為軌跡&#xff0c;構建精準的用戶行為深度洞察模型。這一模型不僅支撐內容分發的動…

Python 字符串(str)全方位剖析:從基礎入門、方法詳解到跨語言對比與知識拓展

Python 字符串&#xff08;str&#xff09;全方位剖析&#xff1a;從基礎入門、方法詳解到跨語言對比與知識拓展 本文將深入探討 Python 中字符串&#xff08;str&#xff09;的相關知識&#xff0c;涵蓋字符串的定義、創建、基本操作、格式化等內容。同時&#xff0c;會將 Py…

使用C++實現簡單的TCP服務器和客戶端

使用C實現簡單的TCP服務器和客戶端 介紹準備工作1. TCP服務器實現代碼結構解釋 2. TCP客戶端實現代碼結構解釋 3. 測試1.編譯&#xff1a;2.運行 結語 介紹 本文將通過一個簡單的例子&#xff0c;介紹如何使用C實現一個基本的TCP服務器和客戶端。這個例子展示了如何創建服務器…

Java Web開發實戰與項目——Spring Boot與Spring Cloud微服務項目實戰

企業級應用中&#xff0c;微服務架構已經成為一種常見的開發模式。Spring Boot與Spring Cloud提供了豐富的工具和組件&#xff0c;幫助開發者快速構建、管理和擴展微服務應用。本文將通過一個實際的微服務項目&#xff0c;展示如何使用Spring Boot與Spring Cloud構建微服務架構…

VMware建立linux虛擬機

本文適用于初學者&#xff0c;幫助初學者學習如何創建虛擬機&#xff0c;了解在創建過程中各個選項的含義。 環境如下&#xff1a; CentOS版本&#xff1a; CentOS 7.9&#xff08;2009&#xff09; 軟件&#xff1a; VMware Workstation 17 Pro 17.5.0 build-22583795 1.配…

Linux8-互斥鎖、信號量

一、前情回顧 void perror(const char *s);功能&#xff1a;參數&#xff1a; 二、資源競爭 1.多線程訪問臨界資源時存在資源競爭&#xff08;存在資源競爭、造成數據錯亂&#xff09; 臨界資源&#xff1a;多個線程可以同時操作的資源空間&#xff08;全局變量、共享內存&a…

LD_PRELOAD 繞過 disable_function 學習

借助這位師傅的文章來學習通過LD_PRELOAD來繞過disable_function的原理 【PHP繞過】LD_PRELOAD bypass disable_functions_phpid繞過-CSDN博客 感謝這位師傅的貢獻 介紹 靜態鏈接&#xff1a; &#xff08;1&#xff09;舉個情景來幫助理解&#xff1a; 假設你要搬家&#x…

【無人集群系列---無人機集群編隊算法】

【無人集群系列---無人機集群編隊算法】 一、核心目標二、主流編隊控制方法1. 領航-跟隨法&#xff08;Leader-Follower&#xff09;2. 虛擬結構法&#xff08;Virtual Structure&#xff09;3. 行為法&#xff08;Behavior-Based&#xff09;4. 人工勢場法&#xff08;Artific…

Oracle Fusion Middleware更改weblogic密碼

前言 當用戶忘記weblogic密碼時&#xff0c;且無法登錄到web界面中&#xff0c;需要使用服務器命令更改密碼 更改方式 1、備份 首先進入 weblogic 安裝目錄&#xff0c;備份三個文件&#xff1a;boot.properties&#xff0c;DefaultAuthenticatorInit.ldift&#xff0c;Def…

MongoDB 復制(副本集)

MongoDB 復制(副本集) 引言 MongoDB是一個高性能、可擴展、易于使用的文檔存儲系統。它以JSON-like的文檔存儲結構&#xff0c;支持靈活的數據模型。在分布式系統中&#xff0c;為了提高數據可用性和系統穩定性&#xff0c;常常需要實現數據的備份和冗余。MongoDB提供了副本集…

【Erdas實驗教程】009:非監督分類及分類后評價

文章目錄 一、分類過程二、分類評價ERDAS 的 ISODATA 算法是基于最小光譜距離來進行的非監督分類,聚類過程始于任意聚類平均值或一個已有分類模板的平均值;聚類每重復一次,聚類的平均值就更新一次,新聚類的均值再用于下次聚類循環。這個過程不斷重復,直到最大的循環次數已…

一周學會Flask3 Python Web開發-Jinja2模板訪問對象

鋒哥原創的Flask3 Python Web開發 Flask3視頻教程&#xff1a; 2025版 Flask3 Python web開發 視頻教程(無廢話版) 玩命更新中~_嗶哩嗶哩_bilibili 如果渲染模板傳的是對象&#xff0c;如果如何來訪問呢&#xff1f; 我們看下下面示例&#xff1a; 定義一個Student類 cla…

git 命令 設置別名

在Git中&#xff0c;您可以通過以下命令查看所有的alias&#xff08;別名&#xff09;&#xff1a; git config --get-regexp alias 這個命令會列出所有配置的alias&#xff0c;例如&#xff1a; alias.st.status alias.co.checkout alias.br.branch ... 如果您想查看某個特定a…

React Router v5 vs v6 路由配置對比

React Router v5 vs v6 路由配置對比 React Router 是 React 中最常用的路由庫&#xff0c;從 v5 到 v6 版本&#xff0c;發生了較大變化。本文對比 React Router v5 和 React Router v6 的配置方式&#xff0c;幫助開發者順利遷移。 1. 安裝依賴 React Router v5 npm inst…

機器學習,我們主要學習什么?

機器學習的發展歷程 機器學習的發展歷程&#xff0c;大致分為以下幾個階段&#xff1a; 1. 起源與早期探索&#xff08;20世紀40年代-60年代&#xff09; 1949年&#xff1a;Hebb提出了基于神經心理學的學習機制&#xff0c;開啟了機器學習的先河1950年代&#xff1a;機器學習的…

全面理解-深拷貝與淺拷貝

在 C 中&#xff0c;深拷貝&#xff08;Deep Copy&#xff09; 和 淺拷貝&#xff08;Shallow Copy&#xff09; 是兩種完全不同的對象拷貝策略&#xff0c;主要區別在于對指針和動態分配資源的處理方式。正確理解二者的區別是避免內存泄漏、懸空指針和程序崩潰的關鍵。 一、核…

藍橋杯第十六屆嵌入式模擬編程題解析

由硬件框圖可以知道我們要配置LED 和按鍵 LED 先配置LED的八個引腳為GPIO_OutPut&#xff0c;鎖存器PD2也是&#xff0c;然后都設置為起始高電平&#xff0c;生成代碼時還要去解決引腳沖突問題 按鍵 按鍵配置&#xff0c;由原理圖按鍵所對引腳要GPIO_Input 生成代碼&#xf…

在 JavaScript 中,[](空數組)不是假值,它是“真值”(truthy)

文章目錄 語法解釋!this.form.productPhotos 的含義在代碼中的作用具體判斷 實際上下文總結當前代碼的局限 在你的父組件代碼中&#xff0c;出現了 !this.form.productPhotos 這樣的表達式&#xff0c;具體是在 handleSubmit 方法中&#xff1a; private handleSubmit() {if (…