这道题目和求组合的思路差不多,比较简单。依次读取数字,然后把数字可以代表的字符依次加到当前的所有结果中,然后进入下一次迭代。假设总共有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的面试中遇到了,所以还是要重视一下,就是一些数组操作的小细节。相关的扩展是这道题如何用递归来解,思路其实类似,就是对于当前字符,递归剩下的数字串,然后得到结果后加上自己返回回去,大家可以试试。如果有问题,欢迎留言讨论哈。
If input string is "230", then I get this output: ["ad ", "ae ", "af ", "bd ", "be ", "bf ", "cd ", "ce ", "cf "], when I run the above code to test.
回复删除Should the result be ["ad", "ae", "af", "bd", "be", "bf", "cd", "ce", "cf"]? Thank you very much.
if 0 represents " ", then the result should be "ad ", "ae ", etc.
删除知道了,谢谢~
删除如果input是“12” ,output是[]
回复删除.......................
这个呢,输入如果是“12”, 输出就是空的了,谢谢~
删除所以正确的输出是空的,不是[“a”,“b”,“c”]么? 感觉leetcode原问题好像描述的不是很清楚啊
删除恩,是的~ 这个面试的时候跟面试官讨论就可以了哈~
删除