关于java:LeetCode017电话号码的字母组合

5次阅读

共计 1600 个字符,预计需要花费 4 分钟才能阅读完成。

电话号码的字母组合

题目形容:给定一个仅蕴含数字 2-9 的字符串,返回所有它能示意的字母组合。答案能够按 任意程序 返回。

给出数字到字母的映射如下(与电话按键雷同)。留神 1 不对应任何字母。

示例阐明请见 LeetCode 官网。

起源:力扣(LeetCode)
链接:https://leetcode-cn.com/probl…
著作权归领扣网络所有。商业转载请分割官网受权,非商业转载请注明出处。

解法一:解法一

首先,将所有的映射列出来 mappings,而后,遍历digits 中的每一个字符,从 mappings 中取出对应的字母,拼到一起,最终遍历完后把后果放到后果集外面,返回。

import java.util.*;

public class Solution {private static Map<Integer, List<Character>> mappings = new HashMap<>();

    static {mappings.put(2, new ArrayList<>(Arrays.asList('a', 'b', 'c')));
        mappings.put(3, new ArrayList<>(Arrays.asList('d', 'e', 'f')));
        mappings.put(4, new ArrayList<>(Arrays.asList('g', 'h', 'i')));
        mappings.put(5, new ArrayList<>(Arrays.asList('j', 'k', 'l')));
        mappings.put(6, new ArrayList<>(Arrays.asList('m', 'n', 'o')));
        mappings.put(7, new ArrayList<>(Arrays.asList('p', 'q', 'r', 's')));
        mappings.put(8, new ArrayList<>(Arrays.asList('t', 'u', 'v')));
        mappings.put(9, new ArrayList<>(Arrays.asList('w', 'x', 'y', 'z')));
    }

    public static List<String> letterCombinations(String digits) {if (digits == null || digits.length() == 0) {return new ArrayList<>();
        }
        Set<String> result = new HashSet<>();
        for (Character temp : mappings.get(Integer.valueOf(String.valueOf(digits.charAt(0))))) {result.add(temp.toString());
        }
        for (int i = 1; i < digits.length(); i++) {
            Set<String> tempResult = result;
            result = new HashSet<>();
            for (String s : tempResult) {for (Character character : mappings.get(Integer.valueOf(String.valueOf(digits.charAt(i))))) {if (!result.contains(s + character)) {result.add(s + character);
                    }
                }
            }
        }
        return new ArrayList<>(result);
    }

    public static void main(String[] args) {List<String> strings = letterCombinations("2");
        for (String string : strings) {System.out.print(string + "--");
        }
    }
}

【每日寄语】睡去昨天的疲乏,忘却昨天的懊恼,睁开明天的双眼,关上明天的美妙。

正文完
 0