17. Letter Combinations of a Phone Number

栏目: ASP.NET · 发布时间: 7年前

内容简介:Given a string containing digits from 2-9 inclusive, return all possible letter combinations that the number could represent.A mapping of digit to letters (just like on the telephone buttons) is given below. Note that 1 does not map to any letters.

Given a string containing digits from 2-9 inclusive, return all possible letter combinations that the number could represent.

A mapping of digit to letters (just like on the telephone buttons) is given below. Note that 1 does not map to any letters.

17. Letter Combinations of a Phone Number

Example:

Input: "23"

Output: ["ad", "ae", "af", "bd", "be", "bf", "cd", "ce", "cf"].

Note:

Although the above answer is in lexicographical order, your answer could be in any order you want.

难度:medium

题目:

给定字符串包含数字2到9,返回所有字母组合。数字字母的对应关系如下图所示。注意1不与任何字母对应。

思路:

组合,递归

Runtime: 2 ms, faster than 80.94% of Java online submissions for Letter Combinations of a Phone Number.

Memory Usage: 26.4 MB, less than 14.87% of Java online submissions for Letter Combinations of a Phone Number.

class Solution {
    public List<String> letterCombinations(String digits) {
        List<String> result = new ArrayList();
        if (digits.isEmpty()) {
            return result;
        }
        
        Map<Character, String> mcs = new HashMap<>();
        mcs.put('2', "abc");
        mcs.put('3', "def");
        mcs.put('4', "ghi");
        mcs.put('5', "jkl");
        mcs.put('6', "mno");
        mcs.put('7', "pqrs");
        mcs.put('8', "tuv");
        mcs.put('9', "wxyz");
        
        StringBuilder s = new StringBuilder();
        letterCombinations(digits, 0, mcs, result, s);

        return result;
    }
    
    private void letterCombinations(String digits, int digitIdx, Map<Character, String> mcs, List<String> result, StringBuilder s) {
        if (s.length() == digits.length()) {
            result.add(s.toString());
            return;
        }
        char[] cs = digits.toCharArray();
        for (int i = digitIdx; i < cs.length; i++) {
            String str = mcs.get(cs[i]);
            for (int j = 0; j < str.length(); j++) {
                s.append(str.charAt(j));
                letterCombinations(digits, i + 1, mcs, result, s);
                s.deleteCharAt(s.length() - 1);
            }
        }
    }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

C语言入门经典

C语言入门经典

霍顿 (Ivor Horton) / 清华大学出版社 / 2008-4-1 / 69.80元

本书是编程语言先驱者Ivor Horton的经典之作,是C语言方面最畅销的图书品种之一。本书集综合性、实用性为一体,是学习C语言的优秀入门教材,在世界范围内广受欢迎,口碑极佳。书中除了讲解C程序设计语言,还广泛介绍了作为一名C程序设计人员应该掌握的必要知识,并提供了大量的实用性很强的编程实例。本书的目标是使你在C语言程序设计方面由一位初学者成为一位称职的程序员。读者基本不需要具备任何编程知识,即可......一起来看看 《C语言入门经典》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具