C++?電話號碼的字母組合功能實(shí)現(xiàn)
電話號碼的字母組合
描述
給定一個(gè)僅包含數(shù)字 2-9 的字符串,返回所有它能表示的字母組合。答案可以按 任意順序 返回。
給出數(shù)字到字母的映射如下(與電話按鍵相同)。注意 1 不對應(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)長度為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);
}
};到此這篇關(guān)于C++ 電話號碼的字母組合的文章就介紹到這了,更多相關(guān)C++ 電話號碼的字母組合內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
利用C++的基本算法實(shí)現(xiàn)十個(gè)數(shù)排序
以下是對利用C++的基本算法實(shí)現(xiàn)十個(gè)數(shù)排序的代碼進(jìn)行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助2013-10-10
C++?使用getline()從文件中讀取一行字符串方法示例
這篇文章主要介紹了C++?使用getline()從文件中讀取一行字符串方法示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09
C/C++?Qt?給ListWidget組件增加右鍵菜單功能
本篇文章給大家介紹ListWidget組件增加一個(gè)右鍵菜單,當(dāng)用戶在ListWidget組件中的任意一個(gè)子項(xiàng)下右鍵,我們讓其彈出這個(gè)菜單,并根據(jù)選擇提供不同的功能,感興趣的朋友跟隨小編一起看看吧2021-11-11
Cocos2d-x學(xué)習(xí)筆記之Hello World!
這篇文章主要介紹了Cocos2d-x學(xué)習(xí)筆記之Hello World!本文基于vs2010和C++語言開發(fā),需要的朋友可以參考下2014-09-09
C++的get()函數(shù)與getline()函數(shù)使用詳解
這篇文章主要介紹了C++的get()函數(shù)與getline()函數(shù)使用詳解,是C++入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2015-09-09

