中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java電話號碼的字母組合問題怎么解決

發布時間:2023-03-13 13:47:32 來源:億速云 閱讀:133 作者:iii 欄目:開發技術

這篇文章主要介紹了Java電話號碼的字母組合問題怎么解決的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Java電話號碼的字母組合問題怎么解決文章都會有所收獲,下面我們一起來看看吧。

電話號碼的字母組合

中等

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

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

Java電話號碼的字母組合問題怎么解決

示例 1:

輸入:digits = "23"

輸出:["ad","ae","af","bd","be","bf","cd","ce","cf"]

示例 2:

輸入:digits = ""

輸出:[]

示例 3:

輸入:digits = "2"

輸出:["a","b","c"]

題解

  • 先把2-9對應的字符用一個map存起來

  • 我們可以知道這是一個全排列的問題

  • 每次我們找到一組滿足條件的組合,只需把最后一個字符刪除在找下一個,知道找完第一個字符對應的所有組合,回溯上一個字符往下,繼續之前的操作

  • 因為不確定有幾個確定字符,所以用遞歸的方式來確定for循環的次數

例如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對應的字符遍歷,每次遍歷會先把該字符存入一個list1容器,遞歸該方法會在嵌套一個for循環3對應字符長度,如果還有則繼續嵌套,當lsit1容器大小與digits長度一樣,說明找到了一組解,遍歷存入集合結束該循環,代碼在下方,因為要回溯,所以每次調用該方法后會把該list1長度減一,實現回溯的過程

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);
        }
    }
}

關于“Java電話號碼的字母組合問題怎么解決”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Java電話號碼的字母組合問題怎么解決”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

乌兰浩特市| 大同市| 章丘市| 延庆县| 曲沃县| 阿巴嘎旗| 嵊州市| 自治县| 定襄县| 萝北县| 宁河县| 剑川县| 舒城县| 潼关县| 万安县| 临泽县| 宁安市| 聂拉木县| 光泽县| 昭通市| 金秀| 博兴县| 崇左市| 大厂| 定州市| 高密市| 呼图壁县| 新野县| 云南省| 措美县| 镇原县| 延安市| 河池市| 青川县| 枣阳市| 呼玛县| 佛教| 东兰县| 顺昌县| 赤峰市| 改则县|