码迷,mamicode.com
首页 > 其他好文 > 详细

LeetCode 17. Letter Combinations of a Phone Number (电话号码的字母组合)

时间:2020-03-16 09:43:10      阅读:58      评论:0      收藏:0      [点我收藏+]

标签:app   append   来源   backtrac   backtrack   https   http   nbsp   htm   

题目标签:Backtracking

  建立一个hashmap 把数字 对应 字母 存入 map;

  利用dfs,每次存入一个 char,当 chars 达到 digtis 的size 返回,具体看code。

  

 

Java Solution: 

Runtime:  0 ms, faster than 100.00 % 

Memory Usage: 38.7 MB, less than 6.16 %

完成日期:12/15/2019

关键点:HashMap

class Solution {
    
    List<String> res;
    HashMap<Character, String> map;
    
    public List<String> letterCombinations(String digits) {
        res = new ArrayList<>();
        map = new HashMap<>();
        StringBuilder comb = new StringBuilder();
        
        if(digits.length() == 0)
            return res;
        
        map.put(‘2‘, "abc");
        map.put(‘3‘, "def");
        map.put(‘4‘, "ghi");
        map.put(‘5‘, "jkl");
        map.put(‘6‘, "mno");
        map.put(‘7‘, "pqrs");
        map.put(‘8‘, "tuv");
        map.put(‘9‘, "wxyz");
        
        DFS(digits, 0, comb);
        
        return res;
    }
    
    
    private void DFS(String digits, int pos, StringBuilder comb) {
        if(pos == digits.length()) {
            res.add(comb.toString());
            return;
        } 
        
        // go through each char
        for(char c : map.get(digits.charAt(pos)).toCharArray()) {
            comb.append(c);
            DFS(digits, pos+1, comb);
            comb.deleteCharAt(comb.length()-1);
        }
        
            
    }
}

参考资料:n/a

LeetCode 题目列表 - LeetCode Questions List

题目来源:https://leetcode.com/

LeetCode 17. Letter Combinations of a Phone Number (电话号码的字母组合)

标签:app   append   来源   backtrac   backtrack   https   http   nbsp   htm   

原文地址:https://www.cnblogs.com/jimmycheng/p/12501633.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!