【雙指針】專題:LeetCode 18題解——四數之和

四數之和

  • 一、題目鏈接
  • 二、題目
  • 三、題目解析
  • 四、算法原理
    • 解法一:排序 + 暴力枚舉 + 利用 set 去重
    • 解法二:排序 + 雙指針
  • 五、編寫代碼
  • 六、時間復雜度和空間復雜度

一、題目鏈接

四數之和

二、題目

在這里插入圖片描述

三、題目解析

題目要求基本與三數之和一樣。

四、算法原理

解法幾乎照搬三數之和

解法一:排序 + 暴力枚舉 + 利用 set 去重

絕對超時,時間復雜度是O(n^4)。

解法二:排序 + 雙指針

示例1排好序:

在這里插入圖片描述

步驟:

  1. 排序
  2. 從左向右依次固定一個數a
  3. 在a的右區間內,利用"三數之和"找到三個數,使這三個數之和等于target - a即可:從左向右依次固定一個數b,在b的右區間內利用"雙指針"找到兩個數,使這兩個數之和等于target - a - b即可。

代碼大體樣子:兩層for循環,中間套了一個雙指針算法。不過這只是大體樣子,還需要解決和"三數之和"同樣的細節問題:結果不重且不漏。

不重:"三數之和"僅有兩個地方。因為這里多了一個數,所以有3個地方要保證不重

  • 找到一個四元組結果,left和right都要跳過重復元素
  • 每使用完一遍"雙指針",b也跳過重復元素
  • b每遍歷完一遍,a也跳過重復元素

不漏:"雙指針"找到一結果就縮小區間。

五、編寫代碼

class Solution {
public:vector<vector<int>> fourSum(vector<int>& nums, int target) {vector<vector<int>> ret;// 1.排序sort(nums.begin(), nums.end());// 2.固定數a,固定數b,雙指針算法int n = nums.size();for (int i = 0; i < n; )// 固定數a{// 三數之和for (int j = i + 1; j < n; )// 固定數b{// 雙指針int aim = target - nums[i] - nums[j];int left = j + 1, right = n - 1;while (left < right){int sum = nums[left] + nums[right];if (sum > aim) --right;else if (sum < aim) ++left;else{// 找到一結果就push_back,保證不漏縮小區間ret.push_back({ nums[i], nums[j], nums[left++], nums[right--]});// 去重 left和rightwhile (left < right && nums[left] == nums[left - 1]) ++left;while (left < right && nums[right] == nums[right + 1]) --right;}}// 去重j++j;while (j < n && nums[j] == nums[j - 1]) ++j;}// 去重i++i;while (i < n && nums[i] == nums[i - 1]) ++i;}return ret;}
};

數據范圍溢出的風險,計算的時候可能會超出int的范圍:

在這里插入圖片描述

可以用long long類型的變量存儲,后面的計算過程只用對第一個數據/第二個數據強制轉換:

long long aim = (long long)target - nums[i] - nums[j];
long long aim = target - (long long)nums[i] - nums[j];

完整代碼:

class Solution {
public:vector<vector<int>> fourSum(vector<int>& nums, int target) {vector<vector<int>> ret;// 1.排序sort(nums.begin(), nums.end());// 2.固定數a,固定數b,雙指針算法int n = nums.size();for (int i = 0; i < n; )// 固定數a{// 三數之和for (int j = i + 1; j < n; )// 固定數b{// 雙指針long long aim = target - (long long)nums[i] - nums[j];if (nums[i] > 0 && nums[j] > 0 && target < 0) break; int left = j + 1, right = n - 1;while (left < right){int sum = nums[left] + nums[right];if (sum > aim) --right;else if (sum < aim) ++left;else{// 找到一結果就push_back,保證不漏縮小區間ret.push_back({ nums[i], nums[j], nums[left++], nums[right--]});// 去重 left和rightwhile (left < right && nums[left] == nums[left - 1]) ++left;while (left < right && nums[right] == nums[right + 1]) --right;}}// 去重j++j;while (j < n && nums[j] == nums[j - 1]) ++j;}// 去重i++i;while (i < n && nums[i] == nums[i - 1]) ++i;}return ret;}
};

六、時間復雜度和空間復雜度

for循環嵌套for循環嵌套while循環,所以時間復雜度是O(n^3)

空間復雜度依舊是排序算法占空間,所以空間復雜度是O(logn)

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

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

相關文章

3.0/Q2,Charls最新文章解讀

diseases and depressive symptoms comorbidity on the risk of cognitive impairment in middle-aged and older adults people based on the CHARLS database DOI&#xff1a;10.3389/fpubh.2025.1558430 中文標題&#xff1a;基于CHARLS數據庫的慢性病與抑郁癥狀共病對中老年…

學習筆記—雙指針算法—移動零

雙指針算法 移動零 283. 移動零 - 力扣&#xff08;LeetCode&#xff09; 題目描述&#xff1a; 給定一個數組 nums&#xff0c;編寫一個函數將所有 0 移動到數組的末尾&#xff0c;同時保持非零元素的相對順序。 請注意 &#xff0c;必須在不復制數組的情況下原地對數組進…

組件的基本知識

組件 組件的基本知識 組件概念組成步驟好處全局注冊生命周期scoped原理 父子通信步驟子傳父 概念 就是將要復用的標簽&#xff0c;抽離放在一個獨立的vue文件中&#xff0c;以供主vue文件使用 組成 三部分構成 template&#xff1a;HTML 結構 script: JS 邏輯 style: CSS 樣…

將視頻生成視頻二維碼步驟

如何將視頻鏈接生成二維碼 生成與視頻關聯的二維碼通常涉及以下幾個方面&#xff1a;選擇合適的庫或工具、準備視頻鏈接以及將其轉換為二維碼圖像。以下是詳細的說明&#xff1a; 使用JavaScript/Vue框架生成二維碼 在前端開發中&#xff0c;可以使用 qrcode 或者 vue-qrcod…

關系型數據庫PostgreSQL for Mac 保姆級使用教程

第一部分&#xff1a;安裝PostgreSQL 方法一&#xff1a;使用Postgres.app&#xff08;最簡單&#xff09; 訪問 Postgres.app官網 下載最新版本&#xff0c;將 Postgres.app 移動到 “Applications” 文件夾。 雙擊Postgres.app打開應用&#xff0c;點擊"Initialize&q…

Redis超詳細入門教程(基礎篇)

一&#xff1a;Redis 簡介 &#xff08;1&#xff09;Mysql: 將數據通過數據文件存在磁盤上 通過二維表存儲數據 &#xff08;2&#xff09;Redis 定義&#xff1a; 優點&#xff1a; 熱點數據&#xff1a;短時間內有大量用戶訪問 二&#xff1a;Redis下載與安裝 Windows系統安…

【JS-Leetcode】2621睡眠函數|2629復合函數|2665計數器||

文章目錄 2621睡眠函數2629復合函數2665計數器|| 這三個題目涉及setTimeout、promise、數組reduce方法&#xff0c;閉包。 2621睡眠函數 請你編寫一個異步函數&#xff0c;它接收一個正整數參數 millis &#xff0c;并休眠 millis 毫秒。要求此函數可以解析任何值。 原理&am…

重塑編程體驗邊界:明基RD280U顯示器深度體驗

重塑編程體驗邊界&#xff1a;明基RD280U顯示器深度體驗 寫在前面 本文將以明基RD280U為核心&#xff0c;通過技術解析、實戰體驗與創新案例&#xff0c;揭示專業顯示器如何重構開發者的數字工作臺。 前言&#xff1a;當像素成為生產力的催化劑 在GitHub的年度開發者調查中&…

如何通過挖掘需求、SEO優化及流量變現成功出海?探索互聯網產品的盈利之道

挖掘需求&#xff0c;優化流量&#xff0c;實現變現&#xff1a;互聯網出海產品的成功之路 在當今全球化的數字時代&#xff0c;越來越多的企業和個人選擇將業務擴展到國際市場。這一趨勢不僅為企業帶來了新的增長機會&#xff0c;也為個人提供了通過互聯網產品實現盈利的途徑…

cuda學習2:cuda編程基本概念

CUDA基本概念 主機&#xff08;host&#xff09; 通常將起控制作用的CPU稱為主機&#xff08;host&#xff09; 設備&#xff08;device&#xff09; 將起加速作用的 GPU 稱為設備&#xff08;device&#xff09; 流處理器&#xff08;streaming processor&#xff09; 物…

AVL樹的介紹與學習

目錄 1.前言 2.AVL樹 3.AVL樹的插入 平衡因子的更新 更新停止的條件 旋轉 1.前言 在學習了二叉搜索樹&#xff0c;set和map之后&#xff0c;我們接下來趁熱打鐵&#xff0c;繼續學習AVL樹。 2.AVL樹 1.AVL樹具有二叉搜索樹的性質&#xff0c;但是它的左右子樹的高度差不…

數字人接大模型第二步:實時語音同步

接上例第一步,還是dh_live項目,增加了一個完整的實時對話樣例,包含vad-asr-llm-tts-數字人全流程,以彌補之前的只有固定的問答的不足。 VAD(Voice Activity Detection,語音活動檢測)VAD用于檢測用戶是否正在說話,從而觸發后續的語音處理流程。 ASR(Automatic Speech R…

01_Long比較值 類型相同值不同

問題描述&#xff1a; 看如下代碼&#xff1a; Long a 128L; Long b 128L;System.out.println(a b);運行結果如下&#xff1a; 明明 a 和 b 的值一樣&#xff0c;但是結果卻為 False&#xff0c;為什么同樣的類型&#xff0c;同樣的值&#xff0c;卻不相等&#xff0c;這是…

EKS環境下服務重啟50X錯誤

EKS中&#xff0c;當使用AWS Load Balancer Controller時&#xff0c;ALB有兩種模式&#xff0c;Internet-facing和Internet&#xff0c;當使用Internet模式時&#xff0c;ALB注冊的是NodeIP&#xff1b;使用Internet-facing模式時&#xff0c;ALB注冊的則是Pod IP。從模式上來…

Android項目升級插件到kotlin 2.1.0后混淆網絡請求異常

背景 項目kt插件1.9.24升級到2.1.0后打包編譯release網絡請求失敗了。 retrofit版本2.9.0 錯誤詳情 java.lang.ClassCastException: java.lang.Class cannot be cast to java.lang.reflect.ParameterizedTypeat retrofit2.m.a(Unknown Source:2477)at retrofit2.K.invoke(U…

Vue中Axios實戰指南:高效網絡請求的藝術

Axios作為Vue生態中最流行的HTTP客戶端&#xff0c;以其簡潔的API和強大的功能成為前后端交互的首選方案。本文將帶你深入掌握Axios在Vue項目中的核心用法和高級技巧。 一、基礎配置 1. 安裝與引入 npm install axios 2. 全局掛載&#xff08;main.js&#xff09; import …

Flink維表深度解析

一、維表的概念與作用 維表&#xff08;Dimension Table&#xff09; 是數據倉庫中的核心概念&#xff0c;通常用于存儲靜態或緩慢變化的業務實體信息&#xff08;如用戶資料、商品信息、地理位置等&#xff09;。在實時流處理場景中&#xff0c;維表的作用是為主數據流&#…

SKLearn - Biclustering

文章目錄 Biclustering &#xff08;雙聚類&#xff09;譜二分聚類算法演示生成樣本數據擬合 SpectralBiclustering繪制結果 Spectral Co-Clustering 算法演示使用光譜協同聚類算法進行文檔的二分聚類 Biclustering &#xff08;雙聚類&#xff09; 關于雙聚類技術的示例。 譜…

PostSwigger Web 安全學習:CSRF漏洞2

CSRF 漏洞學習網站&#xff1a;What is CSRF (Cross-site request forgery)? Tutorial & Examples | Web Security Academy CSRF 漏洞&#xff1a;SameSite相關繞過 當瀏覽器訪問服務器時&#xff0c;服務器會在 Cookie 中添加 SameSite 屬性來告訴瀏覽器是否在來自其他…

從基礎到實戰的量化交易全流程學習:1.3 數學與統計學基礎——概率與統計基礎 | 數字特征

從基礎到實戰的量化交易全流程學習&#xff1a;1.3 數學與統計學基礎——概率與統計基礎 | 數字特征 第一部分&#xff1a;概率與統計基礎 第2節&#xff1a;數字特征&#xff1a;期望值、方差、協方差與相關系數 一、期望值&#xff08;Expected Value&#xff09;&#xff1a…