原题链接:
http://oj.leetcode.com/problems/letter-combinations-of-a-phone-number/
这道题目和求组合的思路差不多,比较简单。依次读取数字,然后把数字可以代表的字符依次加到当前的所有结果中,然后进入下一次迭代。假设总共有n个digit,每个digit可以代表k个字符,那么时间复杂度是O(k^n),就是结果的数量,空间复杂度也是一样。代码如下: 代码如下:
public ArrayList<String> letterCombinations(String digits) { ArrayList<String> res = new ArrayList<String>(); res.add(""); if(digits==null || digits.length()==0) return res; for(int i=0;i<digits.length();i++) { String letters = getLetters(digits.charAt(i)); ArrayList<String> newRes = new ArrayList<String>(); for(int j=0;j<res.size();j++) { for(int k=0;k<letters.length();k++) { newRes.add(res.get(j)+Character.toString(letters.charAt(k))); } } res = newRes; } return res;}private String getLetters(char digit){ switch(digit) { case '2': return "abc"; case '3': return "def"; case '4': return "ghi"; case '5': return "jkl"; case '6': return "mno"; case '7': return "pqrs"; case '8': return "tuv"; case '9': return "wxyz"; case '0': return " "; default: return ""; }}
这道题个人觉得没有太多算法和数据结构的思想,但是自己在facebook的面试中遇到了,所以还是要重视一下,就是一些数组操作的小细节。相关的扩展是这道题如何用递归来解,思路其实类似,就是对于当前字符,递归剩下的数字串,然后得到结果后加上自己返回回去,大家可以试试。如果有问题,欢迎留言讨论哈。
再分享一下我老师大神的人工智能教程吧。零基础!通俗易懂!风趣幽默!还带黄段子!希望你也加入到我们人工智能的队伍中来!https://blog.csdn.net/jiangjunshow