Python小練習系列 Vol.3:生成有效括號組合(回溯 + DFS)

🧠 Python小練習系列 Vol.3:生成有效括號組合(回溯 + DFS)

👋 本期我們來刷一道 LeetCode 熱門經典題,借此掌握回溯算法的精髓 —— 生成有效括號組合,是學習遞歸 & DFS 的黃金題型!


🧩 一、題目描述

給定一個整數 n,代表括號對的數量,請你生成所有格式正確的括號組合。

示例:

輸入:n = 3  
輸出:["((()))","(()())","(())()","()(())","()()()"]

🧠 二、解題思路

我們可以用「回溯 + 深度優先搜索(DFS)」的方法,逐步構建每一位括號組合。

合法組合規則:

  • 左括號 ( 的數量不能超過 n
  • 右括號 ) 的數量不能超過左括號數量

回溯核心:

  • 用遞歸函數 dfs(path, left, right)
  • 當 path 滿足長度條件時,將其加入結果
  • 嘗試添加 (),并繼續向下探索

👨?💻 三、Python代碼實現

def generate_parentheses(n):result = []def dfs(path, left, right):if len(path) == 2 * n:result.append(path)returnif left < n:dfs(path + '(', left + 1, right)if right < left:dfs(path + ')', left, right + 1)dfs('', 0, 0)return result

📌 四、運行示例

print(generate_parentheses(3))
# 輸出:['((()))', '(()())', '(())()', '()(())', '()()()']

🧩 五、解題思維小結

步驟說明
定義參數當前構造字符串 path、左括號數 left、右括號數 right
剪枝策略左右括號數量必須符合規則
終止條件path 長度等于 2 * n 即為完整解

? 本題關鍵在于:控制遞歸分支合法性,避免冗余搜索


💡 六、進階思考

  • 💬 輸出的括號組合可以按字典序排列嗎?
  • 🧠 用棧模擬生成過程,可視化 DFS?
  • ?? 如果限制時間/內存,如何提前剪枝?

?? 結語

回溯法很像在“決策樹”中找答案,本題正是練習遞歸與剪枝的完美例子!

📌 下一期預告:迷宮尋路:回溯走迷宮(二維矩陣)


👉 點贊 👍 + 收藏 🌟,練好算法,刷題不慌!

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

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

相關文章

實戰經驗深度解析 | 博睿數據制造行業精選案例集發布!

近年來&#xff0c;我國制造業加速邁向高端化、智能化、綠色化&#xff0c;為經濟高質量發展注入新動能。放眼全球&#xff0c;制造業正加速數字化、智能化轉型&#xff0c;5G、人工智能、邊緣計算等技術與生產全流程深度融合&#xff0c;有力推動柔性化生產與產業鏈協同創新發…

[創業之路-344]:戰略的本質是選擇、聚焦, 是成本/效率/低毛利優先,還是差易化/效益/高毛利優先?無論是成本優先,還是差易化戰略,產品聚焦是前提。

前言&#xff1a; 一、戰略的本質是選擇、聚焦 關于戰略的本質&#xff0c;觸及了商業競爭的核心矛盾&#xff1a;選擇成本優先&#xff08;效率/低毛利&#xff09;還是差異化&#xff08;效益/高毛利&#xff09;&#xff0c;本質上是對企業戰略方向的終極拷問。 1、戰略選…

項目代碼第10講【數據庫運維知識——如何優化數據庫查詢效率?】:各種日志查看;主從復制;分庫分表(MyCat);讀寫分離;區別數據分區、分表、分庫

01. 運維-課程介紹_嗶哩嗶哩_bilibili 一、各種日志查看 二、主從復制 三、分庫分表&#xff08;MyCat&#xff09; 四、讀寫分離 五、區別數據分區、分表、分庫 1、數據庫分區 上圖中的ibd文件&#xff0c;是分區表的數據文件&#xff0c;可以分布在不同的物理設備上&…

OpenCV圖像拼接(10)用于實現圖像拼接過程中的時間流逝(timelapse)效果的一個類cv::detail::Timelapser

操作系統&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 編程語言&#xff1a;C11 算法描述 cv::detail::Timelapser 是 OpenCV 庫中用于實現圖像拼接過程中的時間流逝&#xff08;timelapse&#xff09;效果的一個類。它通常用于將一系列…

Transformer 通關秘籍2:利用 BERT 將文本 token 化

前面兩節分別通過兩個代碼示例展示了模型將文本轉換為 token 之后是什么樣的&#xff0c;希望你可以對此有一個感性的認識。 本節來簡要介紹一下將一個連續的文本轉換為 token 序列的大致過程&#xff0c;這個過程被稱為分詞&#xff0c;也叫 tokenization。 在你沒了解這方面…

Optional的stream方法,flatMap, filter應用

Java 8引入的Optional和Stream徹底改變了我們處理空值和集合操作的方式。本文將深入探討如何將二者結合使用&#xff0c;通過四個核心場景提升代碼的健壯性和簡潔性。 一、Optional構成的Stream&#xff1a;空值自動過濾 當處理Optional集合時&#xff0c;我們常需要過濾掉空…

參加李繼剛線下活動啟發:未來提示詞還會存在嗎?

上周六&#xff0c;我參加了李繼剛老師組織的線下活動。 現場干貨滿滿&#xff0c;尤其是關于 AI 時代提示詞的價值、與 AI 溝通的藝術等話題&#xff0c;李老師的分享如同醍醐灌頂&#xff0c;讓我對 AI 人機協作有了更深的理解。 將幾點核心收獲整理出來&#xff0c;與大家…

Python基礎知識第二天:從格式化到流程控制

Python基礎知識第二天&#xff1a;從格式化到流程控制 大家好&#xff01;今天我們來梳理Python的一些重要基礎知識&#xff0c;包括格式化輸出、輸入函數、運算符以及流程控制語句。 1. 格式化輸出 Python提供了多種格式化輸出的方式&#xff1a; # %d, %f, %s 格式化name &q…

GDB: coredump

前言&#xff1a;一句話如下使用 gdb [exec_file] [core_file] # or gdb -c [core_file] [exec_file] #-c指定轉儲的core文件 gdb -c core.5213 spp_uc_frequent_contact_ol_worker # 進入后輸入bt查看調用棧 bt #顯示所有幀棧 bt 10 #顯示前面10個幀棧(感覺沒啥用) bt …

21_js正則_表單驗證

目錄 正則 一、 正則的概念 二、創建正則方式 2.1 構造函數去創建正則 2.2 字面量去創建正則 2,3 test方法 三、正則修飾符 四、 正則的方法 lastIndex test方法 exec 五、字符串方法 replace match search split 六、正則表達式的構成 元字符-- 定位符 元字…

礦山自動化監測解決方案

1.行業現狀 為貫徹落實《中共中央國務院關于推進安全生產領域改革發展的意見》《“十四五”礦山安全生產規劃》&#xff08;應急〔2022〕64號&#xff09;、《國務院安委會辦公室關于加強礦山安全生產工作的緊急通知》&#xff08;安委辦〔2021〕3號&#xff09;等有關工作部署…

企業級知識庫建設:自建與開源產品集成的全景解析 —— 產品經理、CTO 與 CDO 的深度對話

文章目錄 一、引言二、主流產品與方案對比表三、自建方案 vs. 開源產品集成&#xff1a;技術路徑對比3.1 自建方案3.2 開源產品集成方案 四、結論與個人觀點 一、引言 在當今數據驅動的商業環境中&#xff0c;構建高質量的知識庫已成為企業數字化轉型的關鍵一環。本博客分別從…

【藍橋杯】單片機設計與開發,溫度傳感器DS18B20

一、溫度傳感器概述 結構圖 二、通信過程 三、onewire單總線協議概述 四、單總線的工作原理 黑粗線是單片機發送的&#xff0c;淺的是s18b20回應的 五、溫度傳感器的應用 六、onewire 七、課后習題

Python 在Word中查找并替換文本

在操作Word文檔時&#xff0c;如果想要修正一處反復出現的拼寫錯誤&#xff0c;統一文中前后不一致的術語&#xff0c;或者將文檔中所有的舊聯系方式更新為新號碼。這時我們可以使用 Word中的查找替換功能&#xff0c;快速定位并批量處理文檔中的特定文本&#xff0c;提升編輯效…

Python 筆記 (二)

Python Note 2 1. Python 慢的原因2. 三個元素3. 標準數據類型4. 字符串5. 比較大小: 富比較方法 rich comparison6. 數據容器 (支持*混裝* )一、允許重復類 (list、tuple、str)二、不允許重復類 (set、dict)1、集合(set)2、字典(dict)3、特殊: 雙端隊列 deque 三、數據容器的共…

kill子進程后再wait可以嗎?

在父進程中先使用 kill 函數終止子進程&#xff0c;之后再使用 wait 函數是可行的&#xff0c;下面從原理、使用示例、注意事項幾個方面詳細說明。 原理 kill 函數&#xff1a;其作用是向指定進程發送信號。當向子進程發送 SIGTERM&#xff08;通常用于請求進程正常終止&…

ai-api-union項目,適配各AI廠商api

項目地址&#xff1a;alpbeta/ai-api-union 需求&#xff1a;實現兼容各大模型廠商api的流式對話和同步對話接口&#xff0c;本項目現兼容智譜、豆包、通義、通義版deepseek 設計 一個ChatController類對外暴露這兩個接口&#xff0c;入參都為ChatRequest請求類&#xff0c;…

【QT】QT樣式設計

QT樣式設計 一、QT工程中添加資源文件1.資源文件&#xff1a;2. 添加步驟&#xff1a;3. 新增資源文件以及刪除現有的資源文件4. 使用資源文件 二、QT中的qss語句(樣式設計語句)1. 樣式設計2.常見的qss語句示例代碼&#xff1a; 一、QT工程中添加資源文件 1.資源文件&#xff…

Megatron-LM中的deepseek-v3實現

Megatron-LM&#xff1a;https://github.com/NVIDIA/Megatron-LM/tree/main 使用此倉庫構建的著名的庫也有很多&#xff0c;如: Colossal-AI, HuggingFace Accelerate, and NVIDIA NeMo Framework.Pai-Megatron-Patch工具是阿里人工智能平臺PAI算法團隊研發,ai-Megatron-Patch…

[mlr3] Bootstrap與交叉驗證k-fold cross validation

五折交叉驗證因其無放回分層抽樣和重復驗證機制&#xff0c;成為超參數調優的首選&#xff1b; 而Bootstrap因有放回抽樣的重復性和驗證集的不穩定性&#xff0c;主要服務于參數估計&#xff08;置信區間的計算&#xff09;而非調優。 實際應用中&#xff0c;可結合兩者優勢&am…