LeetCode刷題之HOT100之組合總和

2024/6/3 周一,工作日的第一天。昨晚夢到被導師說去實驗室不積極哈哈哈,風扇開到二級,早上被吹醒。買的書馬上快要到了。上午剛來準備刷題,結果去搞了一下數據庫sql,做的差不多了,還差點格式轉換就差不多出回來了。現在來做題。

1、題目描述

在這里插入圖片描述

2、邏輯分析

無重復數組,給一個目標值target,要求在數組中找出可以使數字和等于target的所有不同組合,且數組中的元素可以被重復使用。那么怎么解呢?我沒有頭緒,看看題解怎么說。官方題解給出算法是使用搜索回溯的方法,里面涉及到深度優先搜索遞歸計算。大致思路:將整個搜索過程用一個樹來表達,即如下圖呈現,每次的搜索都會延伸出兩個分叉,直到遞歸的終止條件,這樣我們就能不重復且不遺漏地找到所有可行解:
在這里插入圖片描述
像上圖中所示:一個個數計算,這樣就不會有被遺漏的元素了。下面看具體代碼實現。

3、代碼演示

public List<List<Integer>> combinationSum(int[] candidates, int target) {// 創建一個結果列表,用于存儲所有可能的組合List<List<Integer>> res = new ArrayList<List<Integer>>();// 創建一個臨時列表,用于存儲當前正在構建的組合List<Integer> combina = new ArrayList<>();// 調用深度優先搜索方法,開始搜索所有可能的組合dfs( candidates,  target, res , combina, 0);// 返回結果列表 return res;}// 深度優先搜索方法,用于遞歸地搜索所有可能的組合public void dfs(int[] candidates, int target, List<List<Integer>> res , List<Integer> combina, int index){// 如果已經遍歷完所有的候選數字,則直接返回if(index == candidates.length){return;}// 如果當前組合的數字之和已經等于目標值target,則將當前組合添加到結果列表中,并返回 if(target == 0){res.add(new ArrayList<Integer> (combina));return;}// 不選擇當前數字,繼續搜索下一個數字dfs(candidates, target, res, combina, index + 1);// 如果目標值target減去當前數字仍然大于等于0,則可以選擇當前數字if(target - candidates[index] >= 0){// 將當前數字添加到當前組合中 combina.add(candidates[index]);// 遞歸調用dfs,目標值變為target減去當前數字 dfs(candidates,target - candidates[index], res, combina, index);// 回溯,將當前數字從組合中移除,以便嘗試其他組合combina.remove(combina.size() - 1);}}

時間復雜度:O(S),其中 S 為所有可行解的長度之和。空間復雜度:O(target)。
邊看邊敲完這段代碼,大致意思明了,但是對一些細枝末節的地方還是稍有欠缺,先放一放,下次再來看看。搞了幾天的后端結果發現搞錯了哈哈,只能重新開始啦,悲慘滴我嗚嗚嗚。再見啦!

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

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

相關文章

springboot打包筆記

文章目錄 多配置文件application.yml本地啟動參數替換profiles&#xff0c;還是要復制文件 項目有各種環境&#xff0c;例如&#xff1a;local&#xff0c;uat&#xff0c;prd等。 各種打包方式一定要熟練掌握。 做此筆記是因為做了那么多項目&#xff0c;也打了很多包&#xf…

QT中如何對引入的第三方庫進行翻譯

1、背景 在我們的程序中,可能會加載其他人寫的模塊,,該模塊是以庫的形式提供的,那么我們程序翻譯時,如何來對引入的第三方庫進行翻譯??? 2、方案 首先,第三方庫會有自己的翻譯文件,并且一般要給我們提供設置翻譯的接口, 例如下:第三方庫給我們暴露一個接口,我們…

軍用電源性能測試有哪些測試項目?需要遵循什么標準?

為了確保軍用電源在極端條件下能夠正常工作&#xff0c;必須對其進行一系列嚴格的性能測試。這些測試不僅包括效率、電壓調整率和負載調整率等基本參數的測試&#xff0c;還包括動態響應能力、絕緣電阻、耐壓測試、溫度系數以及高低溫循環等綜合性能的評估。 測試項目 效率 電壓…

spring 優雅替換bean

方案一&#xff1a;使用 Primary/Qualifier 注解&#xff08;優選&#xff09; 如果有多個相同類型的 Bean 存在&#xff0c;可以將想要優先使用的 Bean 加上 Primary 注解。 Qualifier和Primary注解的區別&#xff1a;Primary注解用于標記具有相同類型的多個實例中的主要實例…

MySQL -- 連接查詢

MySQL使用連接查詢&#xff08;JOIN&#xff09;是為了從多個相關表中獲取數據。連接查詢是一種強大且常用的操作&#xff0c;可以根據某些條件將兩張或多張表中的數據組合在一起&#xff0c;返回一個聯合結果集。 1.為什么使用連接查詢 數據規范化&#xff1a; 數據庫設計時通…

站點被篡改快照被劫持解決服務方法教程_一招制敵

站點被篡改快照被劫持解決服務方法教程_一招制敵 被篡改表現形式&#xff1a; 站點打不開或跳轉到別的網站。 攻擊者目的&#xff1a; 報復、勒索、賣防御產品&#xff08;如DDOS防御產品&#xff09;。 攻擊成本&#xff1a; 工具&#xff08;如VPN購買&#xff09;成本、人…

智能工廠生產設備實時監控技術的UI設計

智能工廠生產設備實時監控技術的UI設計

Flutter的Dart語法入門

文章目錄 前言1. 類型聲明2. 數據類型2.1 基本數據類型常量 2.2 String2.3 集合2.4 unicode 3. Dart函數特征3.1 可變參數列表和默認入參3.2 匿名函數3.3 typedef 4. Dart面向對象4.1 構造函數4.2 訪問權限4.3 類的繼承 參考資料附錄 前言 每個語言都有控制流語句就不寫測試代…

Go 語言的控制結構:條件與循環

Go 語言提供了豐富的控制結構&#xff0c;使得開發者可以編寫出具有復雜邏輯的程序。這些控制結構包括用于條件分支的 if-else 和 switch 語句&#xff0c;循環控制的 for 語句&#xff0c;以及用于控制循環執行流的 break 和 continue 關鍵字。此外&#xff0c;Go 語言還支持 …

約瑟夫游戲(編號+密碼)

編號為1、2、3、...、N的N個人按順時針方向圍坐一圈&#xff0c;每人持有一個密碼&#xff08;正整數&#xff09;。從指定編號為1的人開始&#xff0c;他的密碼為M的初始值&#xff0c;按順時針方向從1號自己開始順序報數&#xff0c;報到指定數M時停止報數&#xff0c;報M的人…

i18n-demo

一、demo 1、資源文件準備 resources下放各個語言文件&#xff0c;直接放resources下都行。我新建一個文件夾&#xff0c;

房地產vr全景展示交互視頻讓購房者更有參與感

在當今房地產市場中&#xff0c;購房者的需求日益多樣化和個性化。為滿足這一趨勢&#xff0c;我們創新性地將VR虛擬現實技術應用于樓盤宣傳&#xff0c;為購房者帶來前所未有的沉浸式購房體驗。 一、地理位置全景展示 通過實景拍攝與VR技術的結合&#xff0c;我們為購房者呈現…

day26-單元測試

1. 單元測試Junit 1.1 什么是單元測試&#xff1f;&#xff08;掌握&#xff09; 1.2 Junit的特點&#xff1f;&#xff08;掌握&#xff09; 1.3 基本用法&#xff1a;&#xff08;掌握&#xff09; 實際開發中單元測試的使用方式&#xff08;掌握&#xff09; public class …

C語言,排序

前言 排序&#xff0c;可以說是數據結構中必不可缺的一環。我們創造數據存儲它&#xff0c;要想知道數據之間的聯系&#xff0c;比較是必不可少的。不然&#xff0c;費勁心思得來的數據若是不能有更多的意義&#xff0c;那么拿到了又有什么用&#xff1f; 排序是計算機內經常進…

風險投資公司正在幫助小投資者購買Anthropic、OpenAI等熱門公司的股票

近年來&#xff0c;風險投資公司對于人工智能&#xff08;AI&#xff09;領域的公司&#xff0c;如Anthropic、Groq、OpenAI等&#xff0c;表現出了極高的投資熱情。這些公司因為它們在AI技術方面的創新而備受矚目。但是&#xff0c;對于很多小投資者來說&#xff0c;由于資金有…

[C#]使用C#部署yolov8的目標檢測tensorrt模型

【測試通過環境】 win10 x64 vs2019 cuda11.7cudnn8.8.0 TensorRT-8.6.1.6 opencvsharp4.9.0 .NET Framework4.7.2 NVIDIA GeForce RTX 2070 Super 版本和上述環境版本不一樣的需要重新編譯TensorRtExtern.dll&#xff0c;TensorRtExtern源碼地址&#xff1a;TensorRT-CShar…

期權的權利金怎么算的

期權權利金的計算涉及多個因素&#xff0c;包括敲定價格、到期時間以及整個期權合約的具體情況。期權的權利金具體的計算公式和因素可能因不同的期權合約和市場條件而有所不同&#xff0c;下文為大家介紹期權的權利金怎么算的 &#xff1f;本文來自&#xff1a;期權醬 一、期權…

【LeetCode】二叉樹oj專題

如有不懂的地方&#xff0c;可查閱往期相關文章&#xff01; 個人主頁&#xff1a;小八哥向前沖~ 所屬專欄&#xff1a;數據結構【c語言】 目錄 單值二叉樹 對稱二叉樹 計算二叉樹的深度 二叉樹的前序遍歷 相同二叉樹 另一棵樹的子樹 二叉樹的構建和遍歷 翻轉二叉樹 判…

spring boot 中的異步@Async

spring boot 開啟異步調用 1、啟動類上添加EnableAsync注解&#xff0c;表示啟動異步 2、在具體實現異步的方法上添加Async注解 package com.example.demo;import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootAppli…

YOLOv3+mAP實現金魚檢測

YOLOv3mAP實現金魚檢測 Git源碼地址&#xff1a;傳送門 準備數據集 按幀數讀取視頻保存圖片 video2frame.py使用labelimg標注工具對圖片進行標注統一圖片大小為 416x416&#xff0c;并把標簽等信息寫成.xml文件 conver_point.py讀取縮放后的標簽圖片&#xff0c;轉為左上角右下…