您好,登錄后才能下訂單哦!
這篇文章主要介紹了Java電話號碼的字母組合問題怎么解決的相關(guān)知識,內(nèi)容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇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電話號碼的字母組合問題怎么解決”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“Java電話號碼的字母組合問題怎么解決”知識都有一定的了解,大家如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。