【代碼隨想錄訓練營】【Day 29】【回溯-3】| Leetcode 39, 41, 131

【代碼隨想錄訓練營】【Day 29】【回溯-3】| Leetcode 39, 41, 131

需強化知識點

  • startInex作用:一是處理是否可以有重復值,二是實現縱向遍歷(不能沒有)
  • 去重要在數組有序的前提下進行
  • 分割問題

題目

39. 組合總和

  • 注意不要在for循環中亂用return,寫到終止條件上,for循環中應該用break
class Solution:def combinationSum(self, candidates: List[int], target: int) -> List[List[int]]:result = []def backtracking(candidates, target, start_index, path_sum, path, result):if path_sum > target:returnif path_sum == target:result.append(path[:])returnfor i in range(start_index, len(candidates)):path_sum += candidates[i]path.append(candidates[i])backtracking(candidates, target, i, path_sum, path, result)path.pop()path_sum -= candidates[i]candidates.sort()backtracking(candidates, target, 0, 0, [], result)        return result

40. 組合總和 II

  • 去重:可以使用used數組,此處應該是同層不能取重復的數,used[i-1] == False,是會重復的情況
    • 使用startIndex去重, i > startIndex,代表是在同層的情況,在進行橫向遍歷
class Solution:def combinationSum2(self, candidates: List[int], target: int) -> List[List[int]]:def backtracking(result, path, target, total, candidates, startIndex):if total == target:result.append(path[:])returnfor i in range(startIndex, len(candidates)):if total + candidates[i] > target:breakif i > startIndex and candidates[i] == candidates[i-1]:continuetotal += candidates[i]path.append(candidates[i])backtracking(result, path, target, total, candidates, i+1)total -= candidates[i]path.pop()result = []candidates.sort()backtracking(result, [], target, 0, candidates, 0)return result

131. 分割回文串

  • 代碼隨想錄思路:遞歸用來縱向遍歷,for循環用來橫向遍歷,切割線(就是圖中的紅線)切割到字符串的結尾位置,說明找到了一個切割方法。
  • 再次注意,for循環內不要亂用return(此處應該為continue),繼續下一種切割方案
    在這里插入圖片描述
class Solution:def partition(self, s: str) -> List[List[str]]:def isPalindrome(s):if len(s) == 1:return Trueleft, right = 0, len(s)-1while left < right:if s[left] != s[right]:return Falseleft += 1right -= 1return Truedef backtracking(s, path, result, startIndex):if startIndex == len(s):result.append(path[:])for i in range(startIndex, len(s)):select = s[startIndex:i+1]if not isPalindrome(select):continuepath.append(select)backtracking(s, path, result, i+1)path.pop()result = []backtracking(s, [], result, 0)return result        

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

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

相關文章

工業控制2D組態界面,丑是丑了點,但非常實用。

工業控制的2D組態界面是用于監控和控制工業過程的界面。它通常具有以下特征&#xff1a; 實時數據顯示&#xff1a;2D組態界面能夠實時顯示傳感器和設備的數據&#xff0c;如溫度、壓力、流量等。這些數據以圖表、儀表盤、數字顯示等形式呈現&#xff0c;使操作人員能夠實時了解…

Android:使用Kotlin搭建MVVM架構模式

一、簡介Android MVVM架構模式 MVVM全稱&#xff1a;Model、View、ViewModel&#xff1b; Model&#xff1a;負責數據的請求、解析、過濾等數據層操作&#xff0c;其中Repository: 提供數據的 API&#xff08;從本地或者網絡&#xff09;。View&#xff1a;負責視圖部分展示Vie…

Spring (18)什么是JdbcTemplate

JdbcTemplate 是 Spring 框架提供的一個主要的類&#xff0c;旨在簡化傳統 JDBC 的使用。它處理了諸如連接管理、異常處理等繁瑣的低級任務&#xff0c;讓開發者可以更專注于執行 SQL 語句和處理結果。JdbcTemplate 屬于 Spring JDBC 模塊&#xff08;spring-jdbc&#xff09;&…

每日力扣刷題day05(小白簡單題)

文章目錄 2024.5.26&#xff08;5題&#xff09;1446.連續字符題解一題解二 2824.統計和小于目標的下標對數目題解一題解二 1768.交替合并字符串題解一題解二題解三 796.旋轉字符串題解一題解二 1304.和為零的 N 個不同整數題解一題解二 2024.5.26&#xff08;5題&#xff09; …

快速冪求逆元與逆元

我上一篇博客鏈接寫的是多個數求乘法逆元而快速冪求逆元用于單個數求乘法逆元 逆元是對分數取模用的 對于除法取模不成立&#xff0c;即(a/b)%p≠(a%p/b%p)%p。求逆元的思路&#xff1a;(一般ACM的題目都是對1e97這種素數取模&#xff0c;所以gcd(a,p)1)a*b1(mod p) > b1/a…

[Algorithm][動態規劃][簡單多狀態DP問題][按摩師][打家劫舍Ⅱ][刪除并獲得點數][粉刷房子]詳細講解

目錄 1.按摩師1.題目鏈接2.算法思路詳解3.代碼實現 2.打家劫舍 II1.題目鏈接2.算法思路詳解3.代碼實現 3.刪除并獲得點數1.題目鏈接2.算法思路詳解3.代碼實現 4.粉刷房子1.題目鏈接2.算法思路詳解3.代碼實現 1.按摩師 1.題目鏈接 按摩師 2.算法思路詳解 思路&#xff1a; 確…

大模型提示詞Prompt學習

引言 關于chatGPT的Prompt Engineer&#xff0c;大家肯定耳朵都聽起繭了。但是它的來由&#xff1f;&#xff0c;怎么能用好&#xff1f;很多人可能并不覺得并不是一個問題&#xff0c;或者說認定是一個很快會過時的概念。但其實也不能說得非常清楚&#xff08;因為覺得沒必要深…

Redis第18講——Redis和Redission實現延遲消息

即使不是做電商業務的同學&#xff0c;也一定知道訂單超時關閉這種業務場景&#xff0c;這個場景大致就是用戶下單后&#xff0c;如果在一定時間內未支付&#xff08;比如15分鐘、半小時&#xff09;&#xff0c;那么系統就會把這筆訂單給關閉掉。這個功能實現的方式有很多種&a…

unity開發Hololens 制作滑動框

一定要做到最后一步&#xff0c;才會有效果 1、創建空物體 ,并添加組件 創建空物體 命名ScrollingObjectCollection&#xff0c; 添加組件如下圖 下面是各個組件展開的內容 2、在ScrollingObjectCollection 下面創建兩個空物體&#xff0c;分別命名Container、Clipping…

運籌說 第115期 | 排隊論經典例題講解

通過前幾期的學習&#xff0c;我們已經學會了排隊論的基本概念、生滅過程和Poisson過程&#xff0c;等待制排隊模型、混合制排隊模型、其他排隊模型以及排隊系統優的定義與相關求解方法。在實際工作中&#xff0c;我們能發現排隊論在經濟管理中有著許多應用&#xff0c;本期小編…

大數據量上傳FTP

背景 筆者有一個需求是把將近一億條數據上傳到FTP服務器中&#xff0c;這些數據目前是存儲在mysql中&#xff0c;是通過關聯幾張表查詢出來的&#xff0c;查詢出來的數據結果集一共是6個字段。要求傳輸的時候拆分成一個個小文件&#xff0c;每個文件大小不能超過500M。我的測試…

FuTalk設計周刊-Vol.052

#AI漫談 熱點捕手 1.ChatGPT 大更新&#xff01;GPT-4 開始又變聰明了 OpenAI 官方宣布&#xff0c;新版 GPT-4 Turbo 今天開始向所有付費 ChatGPT 用戶開放。 鏈接https://www.pconline.com.cn/focus/1733/17330089.html 2.刷爆多模態任務榜單&#xff01;賈佳亞團隊Mini-G…

Linux下環境變量配置出錯導致基礎命令使用不了的問題解決

問題&#xff1a; 當配置環境變量&#xff1a; echo export PATH/home/ubuntu/.local/lib/python3.8/site-packages :$PATH >> ~/.bashrc 執行生效命令 source ~/.bashrc 出現所有的基礎操作命令&#xff1a;ls vim都使用不了 解決方式&#xff1a; 1&#xff09…

21.2zabbix低級自動發現-mysql多實例

配置mysql多實例 注釋&#xff1a;自動發現&#xff1a;創建監控主機&#xff1b;低級自動發現&#xff1a;創建監控項 mysql單實例是直接yum安裝&#xff0c;開啟mysql多實例 準備配置文件 #mysql3307實例 cp /etc/my.cnf /etc/my3307.cnf vim /etc/my3307.cnf [mysqld] dat…

lazarus-IDE 可以開發 Node.js 嗎?

Lazarus IDE 本身不是用來開發 Node.js 應用程序的工具&#xff0c;因為它是一個用于開發跨平臺應用程序的環境&#xff0c;類似于 C Builder 或 Delphi。Node.js 是一個基于 JavaScript 的運行時環境&#xff0c;通常使用 V8 引擎&#xff0c;用于構建異步、事件驅動的服務器端…

產品經理-流程圖結構圖(四)

1. 流程圖 1.1 概念 為了達到特定的目標而進行的一系列有邏輯性的操作步驟&#xff0c;由兩個及以上的步驟&#xff0c;完成一個完整的行為的過程&#xff0c;可稱之為流程 1.2 產品經理為什么需要繪制流程圖&#xff1f; 保證產品的使用邏輯合理順暢向項目組其他成員清晰的…

代碼隨想錄算法訓練營Day4|24. 兩兩交換鏈表中的節點、19.刪除鏈表的倒數第N個節點、 142.環形鏈表II、面試題 02.07. 鏈表相交

24. 兩兩交換鏈表中的節點 這道題的關鍵在于: 1、在置換兩個節點的時候&#xff0c;當前節點需要在這倆節點之前一個節點。并且要提前保存cur.next以及cur.next.next。 2、每次置換完一組節點&#xff0c;cur cur.next.next 3、判斷結束的標志&#xff1a;奇數個節點&#xf…

如何禁止U盤拷貝文件|禁止U盤使用的軟件有哪些

禁止U盤拷貝文件的方法有很多&#xff0c;比如使用注冊表、組策略編輯器等&#xff0c;但這些方法都適合個人&#xff0c;不適合企業&#xff0c;因為企業需要對下屬多臺電腦進行遠程管控&#xff0c;需要方便、省時、省力的方法。目前來說&#xff0c;最好的方法就是使用第三方…

Unity websocket客戶端

&#x1f3c6; 個人愚見&#xff0c;沒事寫寫筆記 &#x1f3c6;《博客內容》&#xff1a;Unity3D開發內容 &#x1f3c6;&#x1f389;歡迎 &#x1f44d;點贊?評論?收藏 &#x1f50e;目標&#xff1a;服務器和客戶端可以實時的傳輸信息 ??實現目標&#xff1a; 使用的w…

技術速遞|無障礙應用程序之旅:鍵盤可訪問性和 .NET MAUI

作者&#xff1a;Rachel Kang 排版&#xff1a;Alan Wang 首先讓我們一起來看看您的應用程序是否支持鍵盤訪問&#xff1a; 啟動您的其中一個應用。如果您的設備尚未連接物理鍵盤&#xff0c;請連接物理鍵盤。像平常一樣導航您的應用程序&#xff0c;并且僅使用鍵盤來執行此操…