網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
電話(huà)號(hào)碼的字母組合
描述
給定一個(gè)僅包含數(shù)字 2-9 的字符串,返回所有它能表示的字母組合。答案可以按 任意順序 返回。
給出數(shù)字到字母的映射如下(與電話(huà)按鍵相同)。注意 1 不對(duì)應(yīng)任何字母。
示例1
輸入:digits = "23"
輸出:["ad","ae","af","bd","be","bf","cd","ce","cf"]
示例2
輸入:digits = ""
輸出:[]
示例3
輸入:digits = "2"
輸出:["a","b","c"]
提示:
0 <= digits.length <= 4
digits[i]
是范圍 ['2', '9']
的一個(gè)數(shù)字。
思路/解法
方式一
回溯算法,在當(dāng)前題目非常適合。先使用map容器記錄所有可能,在回溯遍歷即可。
class Solution { public: void TrackBack(string& digits,int charStart,int size,string& back,vector<string>& res,std::unordered_map<char,string>& maps) { if(back.length() == size) { res.push_back(back); return; } int length = maps[digits[charStart]].length(); std::string str = maps[digits[charStart]]; for(int i = 0;i < length; i++) { back.push_back(str[i]); TrackBack(digits,charStart + 1,size,back,res,maps); back.pop_back(); } } vector<string> letterCombinations(string digits) { vector<string> arrs; if(digits == "") return arrs; std::unordered_map<char,string> maps{{'2',"abc"},{'3',"def"},{'4',"ghi"}, {'5',"jkl"},{'6',"mno"},{'7',"pqrs"},{'8',"tuv"},{'9',"wxyz"}}; string back; TrackBack(digits,0,digits.length(),back,arrs,maps); return arrs; } };
方式二
遞歸法,使用遞歸求解出所有的可能性并合并結(jié)果即可。
class Solution { public: vector<string> CharCombine(string digits,unordered_map<char,string>& maps) { vector<string> tmp; int length = digits.size(); //邊界條件(當(dāng)長(zhǎng)度為0或1時(shí)直接跳出) if(1 == length) { string str = maps[digits[0]]; for(int j = 0;j < str.length();j++) { string s = ""; tmp.push_back(s.append(1,str[j])); } return tmp; } else if(0 == length) return tmp; else//遞歸 { string str = maps[digits[length-1]]; vector<string> res = CharCombine(digits.substr(0,length-1),maps); for(int i = 0;i < str.length();i++) { for(int j = 0;j < res.size();j++) { string t = res[j]; tmp.push_back(t.append(1,str[i])); } } return tmp; } } vector<string> letterCombinations(string digits) { std::unordered_map<char,string> maps{{'2',"abc"},{'3',"def"},{'4',"ghi"}, {'5',"jkl"},{'6',"mno"},{'7',"pqrs"},{'8',"tuv"},{'9',"wxyz"}}; return CharCombine(digits,maps); } };
原文鏈接:https://blog.csdn.net/qq135595696/article/details/126219203
相關(guān)推薦
- 2022-09-24 C#自定義集合初始化器_C#教程
- 2022-07-07 Python?pluggy模塊的用法示例演示_python
- 2022-03-24 詳析C#的協(xié)變和逆變_C#教程
- 2022-04-23 uni-app之項(xiàng)目首頁(yè)實(shí)現(xiàn)步驟
- 2022-09-14 Python詳細(xì)講解淺拷貝與深拷貝的使用_python
- 2022-06-08 FreeRTOS實(shí)時(shí)操作系統(tǒng)支持時(shí)間片示例詳解_操作系統(tǒng)
- 2022-05-16 SQL?Server中常用截取字符串函數(shù)介紹_MsSql
- 2022-09-13 Python利用臨時(shí)文件實(shí)現(xiàn)數(shù)據(jù)的保存_python
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門(mén)
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支