欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java?電話號(hào)碼的組合示例詳解

 更新時(shí)間:2023年03月13日 11:54:17   作者:窺見漫天星光-瑩  
這篇文章主要介紹了Java?電話號(hào)碼的組合,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

電話號(hào)碼的字母組合

中等

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

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

示例 1:

輸入:digits = "23"

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

示例 2:

輸入:digits = ""

輸出:[]

示例 3:

輸入:digits = "2"

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

題解

  • 先把2-9對(duì)應(yīng)的字符用一個(gè)map存起來
  • 我們可以知道這是一個(gè)全排列的問題
  • 每次我們找到一組滿足條件的組合,只需把最后一個(gè)字符刪除在找下一個(gè),知道找完第一個(gè)字符對(duì)應(yīng)的所有組合,回溯上一個(gè)字符往下,繼續(xù)之前的操作
  • 因?yàn)椴淮_定有幾個(gè)確定字符,所以用遞歸的方式來確定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對(duì)應(yīng)的字符遍歷,每次遍歷會(huì)先把該字符存入一個(gè)list1容器,遞歸該方法會(huì)在嵌套一個(gè)for循環(huán)3對(duì)應(yīng)字符長度,如果還有則繼續(xù)嵌套,當(dāng)lsit1容器大小與digits長度一樣,說明找到了一組解,遍歷存入集合結(jié)束該循環(huán),代碼在下方,因?yàn)橐厮?,所以每次調(diào)用該方法后會(huì)把該list1長度減一,實(shí)現(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 電話號(hào)碼的組合的文章就介紹到這了,更多相關(guān)Java 電話號(hào)碼組合內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 解讀為何java中的boolean類型是32位的

    解讀為何java中的boolean類型是32位的

    這篇文章主要介紹了為何java中的boolean類型是32位的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • Java基礎(chǔ)異常處理代碼及原理解析

    Java基礎(chǔ)異常處理代碼及原理解析

    這篇文章主要介紹了java基礎(chǔ)異常處理代碼及原理解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11
  • Java并發(fā)編程之LockSupport類詳解

    Java并發(fā)編程之LockSupport類詳解

    LockSupport是一種線程阻塞工具,它可以在線程內(nèi)任意位置讓線程阻塞.接下來就帶著大家詳細(xì)了解一下LockSupport類,,需要的朋友可以參考下
    2021-05-05
  • Idea 配置國內(nèi) Maven 源的圖文教程

    Idea 配置國內(nèi) Maven 源的圖文教程

    這篇文章主要介紹了Idea 配置國內(nèi) Maven 源的教程,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-11-11
  • Springboot Session共享實(shí)現(xiàn)原理及代碼實(shí)例

    Springboot Session共享實(shí)現(xiàn)原理及代碼實(shí)例

    這篇文章主要介紹了Springboot Session共享實(shí)現(xiàn)原理及代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-08-08
  • Java 選擇排序、插入排序、希爾算法實(shí)例詳解

    Java 選擇排序、插入排序、希爾算法實(shí)例詳解

    這篇文章主要介紹了Java 選擇排序、插入排序、希爾算法實(shí)例詳解,需要的朋友可以參考下
    2017-05-05
  • Shiro在springboot中快速實(shí)現(xiàn)方法

    Shiro在springboot中快速實(shí)現(xiàn)方法

    Apache Shiro是一個(gè)Java的安全(權(quán)限)框架,可以容易的開發(fā)出足夠好的應(yīng)用,既可以在JavaEE中使用,也可以在JavaSE中使用,這篇文章主要介紹了Shiro在springboot中快速實(shí)現(xiàn),需要的朋友可以參考下
    2023-02-02
  • Jenkins+Maven+SVN自動(dòng)化部署java項(xiàng)目

    Jenkins+Maven+SVN自動(dòng)化部署java項(xiàng)目

    這篇文章主要介紹了Jenkins+Maven+SVN自動(dòng)化部署java項(xiàng)目,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • java實(shí)習(xí)--每天打卡十道面試題!

    java實(shí)習(xí)--每天打卡十道面試題!

    臨近秋招,備戰(zhàn)暑期實(shí)習(xí),祝大家每天進(jìn)步億點(diǎn)點(diǎn)!本篇文章準(zhǔn)備了十道java的常用面試題,希望能夠給大家提供幫助,最后祝大家面試成功,進(jìn)入自己心儀的大廠
    2021-06-06
  • jdk8?FunctionalInterface注解源碼解讀

    jdk8?FunctionalInterface注解源碼解讀

    這篇文章主要介紹了jdk8?FunctionalInterface注解源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-11-11

最新評(píng)論