Java?電話號碼的組合示例詳解
電話號碼的字母組合
中等
給定一個僅包含數(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"]
題解
- 先把2-9對應(yīng)的字符用一個map存起來
- 我們可以知道這是一個全排列的問題
- 每次我們找到一組滿足條件的組合,只需把最后一個字符刪除在找下一個,知道找完第一個字符對應(yīng)的所有組合,回溯上一個字符往下,繼續(xù)之前的操作
- 因為不確定有幾個確定字符,所以用遞歸的方式來確定for循環(huán)的次數(shù)
例如23
2=abc
3=def
Character c = digits.charAt(start);
String str = phoneMap.get(c);
for(int i = 0;i < str.length();i++){
list1.add(str.charAt(i));
help(digits,start+1);
list1.remove(list1.size()-1);
}先從map取出2對應(yīng)的字符遍歷,每次遍歷會先把該字符存入一個list1容器,遞歸該方法會在嵌套一個for循環(huán)3對應(yīng)字符長度,如果還有則繼續(xù)嵌套,當(dāng)lsit1容器大小與digits長度一樣,說明找到了一組解,遍歷存入集合結(jié)束該循環(huán),代碼在下方,因為要回溯,所以每次調(diào)用該方法后會把該list1長度減一,實現(xiàn)回溯的過程
class Solution {
List<String> list = new ArrayList<>();
List<Character> list1 = new ArrayList<>();
Map<Character, String> phoneMap = new HashMap<Character, String>() {{
put('2', "abc");
put('3', "def");
put('4', "ghi");
put('5', "jkl");
put('6', "mno");
put('7', "pqrs");
put('8', "tuv");
put('9', "wxyz");
}};
public List<String> letterCombinations(String digits) {
if(digits.length() == 0){
return new ArrayList<>();
}
help(digits,0);
return list;
}
public void help(String digits,int start){
if(list1.size() == digits.length()){
String str = "";
for(int j = 0;j < list1.size();j++){
str += list1.get(j);
}
list.add(str);
return;
}
Character c = digits.charAt(start);
String str = phoneMap.get(c);
for(int i = 0;i < str.length();i++){
list1.add(str.charAt(i));
help(digits,start+1);
list1.remove(list1.size()-1);
}
}
}
到此這篇關(guān)于Java 電話號碼的組合的文章就介紹到這了,更多相關(guān)Java 電話號碼組合內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用SpringBoot讀取Windows共享文件的代碼示例
在現(xiàn)代企業(yè)環(huán)境中,文件共享是一個常見的需求,Windows共享文件夾(SMB/CIFS協(xié)議)因其易用性和廣泛的兼容性,成為了許多企業(yè)的首選,在Java應(yīng)用中,尤其是使用Spring Boot框架時,如何讀取Windows共享文件是一個值得探討的話題,本文介紹了使用SpringBoot讀取Windows共享文件2024-11-11
Java中抽象類和接口的區(qū)別_動力節(jié)點Java學(xué)院整理
java抽象類和接口最本質(zhì)的區(qū)別是接口里不能實現(xiàn)方法--接口中的方法全是抽象方法。抽象類中可實現(xiàn)方法--抽象類中的方法可以不是抽象方法,下文給大家簡單介紹下,需要的的朋友參考下2017-04-04
Spring MVC請求參數(shù)接收的全面總結(jié)教程
這篇文章主要給大家總結(jié)介紹了關(guān)于Spring MVC請求參數(shù)接收的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-08-08
使用sharding-jdbc實現(xiàn)水平分表的示例代碼
本文主要介紹了sharding-jdbc實現(xiàn)水平分表,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-11-11
SpringSecurity詳解整合JWT實現(xiàn)全過程
JWT作為一個開放的標(biāo)準(zhǔn)(?RFC?7519?),定義了一種簡潔的,自包含的方法用于通信雙方之間以Json對象的形式安全的傳遞信息。接下來通過本文給大家介紹springSecurity+jwt實現(xiàn)互踢功能,需要的朋友可以參考下2022-07-07
Spring使用注解方式實現(xiàn)創(chuàng)建對象
這篇文章主要介紹了Spring使用注解方式實現(xiàn)創(chuàng)建對象,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2023-02-02

