python-leetcode 56.電話號碼的字母組合

題目:

給定一個僅包含數字的2-9的字符串,返回所有它可能表示的字母組合,答案可以按任意順序返回

給出數字到字母的映射如下(與電話按鍵相同),注意1不對應任何字母


方法一:深度優先搜索,回溯

遞歸函數

首先使用哈希表存儲每個數字對應的所有可能的字母,然后進行回溯操作。回溯過程中維護一個字符串,表示已有的字母排列,該字符串初始為空。每次取電話號碼的一位數字,從哈希表中獲得該數字對應的所有可能的字母,并將其中的一個字母插入到已有的字母排列后面,繼續處理電話號碼的后一位數字,直到處理完電話號碼中的所有數字,即得到一個完整的字母排列。然后進行回退操作,遍歷其余的字母排列。

.

class Solution(object):def letterCombinations(self, digits):""":type digits: str:rtype: List[str]"""if not digits: #空字符串,則返回空列表 return []phonemap={  #映射數字到對應的字母"2":"abc","3":"def","4":"ghi","5":"jkl","6":"mno","7":"pqrs","8":"tuv","9":'wxyz',}def backtrack(index): #回溯函數 ,處理當前的數字位置if index==len(digits):combinations.append("".join(combination))#將當前combination中的字母組合成字符串,加入 combinations 結果列表else:  #處理當前數字對應的所有可能字母digit=digits[index]  #取出當前 index 位置的數字for letter in phonemap[digit]:#遍歷當前數字 digit 對應的所有字母,2對應“a","b","c"combination.append(letter) #將當前 letter 加入 combination,表示選擇該字母backtrack(index+1)#遞歸調用 ,處理下一個數字的字母組合combination.pop()#回溯:撤銷當前選擇的字母,嘗試下一個可能的字母combination=[]#存儲當前選擇的字母combinations=[]#用于存儲所有可能的字母組合結果backtrack(0)return combinations #所有可能的字母組合

時間復雜度:O(3 **m?×4 **n?),其中 m 是輸入中對應 3 個字母的數字個數(包括數字 2、3、4、5、6、8),n 是輸入中對應 4 個字母的數字個數(包括數字 7、9),m+n 是輸入數字的總個數。

空間復雜度:O(m+n),其中 m 是輸入中對應 3 個字母的數字個數,n 是輸入中對應 4 個字母的數字個數,m+n 是輸入數字的總個數。除了返回值以外,空間復雜度主要取決于哈希表以及回溯過程中的遞歸調用層數,哈希表的大小與輸入無關,可以看成常數,遞歸調用層數最大為 m+n

源自力扣官方題解

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

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

相關文章

keepalived應用

Keepalived 是一個基于 VRRP(虛擬路由冗余協議)實現的高可用解決方案,常用于構建高可用性的服務器集群,特別是在負載均衡場景中,可確保服務的不間斷運行。以下為你詳細介紹它: 0主要功能 高可用性&#x…

5.0 VisionPro調用USB相機的方法與步驟說明(一)

本文介紹如何在C#中調用visionPro以處理USB相機采集到的圖片。示例如下: 主要思路如下: 1. 使用AForge來打開以及采集usb相機照片。 usb相機處于一直運行狀態。每隔100ms采集一次照片。且觸發一次事件。 public void Start() { this.videoSourcePlayer.Stop(); …

論文閱讀:Deep Hybrid Camera Deblurring for Smartphone Cameras

今天介紹一篇 ACM SIGGRAPH 2024 的文章,關于手機影像中的去模糊的文章。 Deep Hybrid Camera Deblurring for Smartphone Cameras Abstract 手機攝像頭盡管取得了顯著的進步,但由于傳感器和鏡頭較為緊湊,在低光環境下的成像仍存在困難&am…

Linux中的基本指令(下)

目錄 mv指令 more指令 less指令 head指令 tail 指令 繼續理解文件 重定向和追加重定向操作 理解管道 find指令 whereis 指令 bc指令 uname ?r指令 grep 指令 關機 擴展命令 zip/unzip 指令 tar指令 關于rzsz 系統間的文件互傳 接上! mv指令 m…

Unity大型游戲開發全流程指南

一、開發流程與核心步驟 1. 項目規劃與設計階段 需求分析 明確游戲類型(MMORPG/開放世界/競技等)、核心玩法(戰斗/建造/社交)、目標平臺(PC/移動/主機)示例:MMORPG需規劃角色成長樹、副本Boss…

Unity WebGL IIS報錯無法使用

Unity WebGL IIS報錯無法使用 原因1:WebGL文件夾無訪問權限 右鍵WebGL文件夾-屬性 點擊安全-編輯-添加 輸入ever點擊確定-應用即可

【JDK17】開源應用服務器大比對

接著 next-public 源代碼分析,Java 應用服務器選用 jetty。但是之前普遍使用 Tomcat,那為什么要用 jetty 么,除了這兩個,Java 應用服務器開源現狀并不了解,故而又是一篇科普性的筆記,以下是 又小又快的 Jav…

docker-compose install nginx(解決fastgpt跨區域)

CORS前言 CORS(Cross-Origin Resource Sharing,跨源資源共享)是一種安全措施,它允許或拒絕來自不同源(協議、域名、端口任一不同即為不同源)的網頁訪問另一源中的資源。它的主要作用如下: 同源策略限制:Web 瀏覽器的同源策略限制了從一個源加載的文檔或腳本如何與另一…

算法刷題記錄——LeetCode篇(4) [第301~400題](持續更新)

(優先整理熱門100及面試150,不定期持續更新,歡迎關注) 322. 零錢兌換 給你一個整數數組 coins ,表示不同面額的硬幣;以及一個整數 amount ,表示總金額。 計算并返回可以湊成總金額所需的最少的硬幣個數。如果沒有任何…

vulnhub靶場之loly靶機

前言 挑戰攻克該靶機30分鐘 靶機:loly靶機,IP地址為192.168.10.11 攻擊:kali,IP地址為192.168.10.6 靶機和攻擊機都采用VMware虛擬機,都采用橋接網卡模式 文章涉及的靶機及工具,都可以自行訪問官網或者項…

Deepseek API+Python測試用例一鍵生成與導出-V1.0.2【實現需求文檔圖片識別與用例生成自動化】

在測試工作中,需求文檔中的圖片(如界面設計圖、流程圖)往往是測試用例生成的重要參考。然而,手動提取圖片并識別內容不僅耗時,還容易出錯。本文將通過一個自研小工具,結合 PaddleOCR 和大模型,自…

Excel(函數篇):COUNTIF與CONUTIFS函數、SUMIF與SUMIFS函數、ROUND函數、MATCH與INDEX函數、混合引用與條件格式

目錄 COUNTIF和COUNTIFS函數COUNTIF函數COUNTIFS函數SUMIF和SUMIFS函數SUMIF函數SUMIFS函數SUMIFS函數與控件實現動態年月匯總ROUND、ROUNDUP、ROUNDDOWN函數單元格混合引用條件格式與公式,標記整行數據MATCH和INDEX函數COUNTIF和COUNTIFS函數 COUNTIF函數 統計下“蘇州”出現…

上位機數據可視化:使用QtCharts繪制波形圖

工程配置 CMake文件 find_package(Qt5 COMPONENTS Charts REQUIRED)target_link_libraries(zhd-desktop PRIVATE Qt5::Charts)包含頭文件以及名稱空間&#xff08;這個很重要&#xff0c;沒有包含名稱空間編譯器會提示找不到相關的類型&#xff09; #include <QtCharts&g…

S32K144入門筆記(十三):LPIT的API函數解讀

目錄 1. SDK中的函數 2. API函數的釋義 2.1 獲取默認參數 2.2 初始化 2.3 啟動與停止 2.4 計數值的設置于讀取 2.5 中斷API 1. SDK中的函數 在使用SDK的非抽象驅動函數時&#xff0c;函數的定義與聲明在文件lpit_driver.c和lpit_driver.h中&#xff0c;一共有19個函數&a…

CSS - Pseudo-classes(偽類選擇器)

目錄 一、介紹二、常用種類三、案例實現案例一&#xff1a;a標簽使用link/visited/hover/active案例二&#xff1a;表單元素使用focus/disabled案例三、通過其余偽類實現元素靈活選中 一、介紹 CSS 偽類&#xff08;Pseudo-classes&#xff09; 用于定義元素的特定狀態或結構位…

http proxy的原理是什么

Http代理的原理 代理服務器會自動提取請求數據包中的HTTP請求數據發送給服務端&#xff0c;并將服務端的HTTP響應數據轉發給發送請求的客戶端&#xff0c;HTTP代理服務器使用的端口通常是8080。 對于Web客戶端來說&#xff0c;代理扮演的服務器角色&#xff0c;接收請求&…

Ubuntu22.04虛擬機里安裝Yolov8流程

1. 安裝pytorch sudo apt install nvidia-cuda-toolkit nvcc --version # 官方適配地址&#xff1a;https://download.pytorch.org/whl/torch/import torch print(torch.__version__) print(torch.cuda.is_available())2. 安裝環境 # cuDNN 安裝&#xff1a;https://develop…

神經網絡微調技術解析

神經網絡微調技術 微調&#xff08;Fine-tuning&#xff09;是遷移學習的核心技術&#xff0c;通過在預訓練模型基礎上調整參數&#xff0c;使其適應特定任務或領域。以下從傳統方法、參數高效微調&#xff08;PEFT&#xff09;、新興技術三個維度展開&#xff0c;覆蓋主流技術…

Spring 聲明式事務管理

Spring 編程的方式實現事務管理&#xff0c;這樣太過麻煩&#xff0c;需要在每個方法上面加上相應的事務處理操作&#xff0c;聲明式事務處理能夠很好的解決這個問題&#xff0c;比如通過tx命名空間&#xff0c;這樣只需要配置就可以檢測到相關的方法&#xff0c;或者是通過tra…

電機控制常見面試問題(十五)

文章目錄 一、電機氣隙二、電氣時間三.電機三環控制詳解四.驅動板跳線意義五.電機開環自檢 一、電機氣隙 電機氣隙是定子和轉子之間的空隙&#xff0c;防止釘子轉子運轉時物理接觸&#xff0c;此外&#xff0c;氣隙是磁路的重要環節&#xff0c;磁場需通過氣隙傳遞能量&#x…