一、题目原型:
给定一个仅包含数字 2-9 的字符串,返回所有它能表示的字母组合。
给出数字到字母的映射如下(与电话按键相同)。注意 1 不对应任何字母。
二、题目意思剖析:
其实呢就是一个排列组合,将字母按照有序的顺序组合起来。1
2
3
4
5
6
7
8
9
10
11
12
13
14
15/*
2-abc
3-def
4-ghi
5-jkl
6-mno
7-pqrs
8-tuv
9-wxyz
输入:"23"
输出:["ad", "ae", "af", "bd", "be", "bf", "cd", "ce", "cf"].
如果输入的是 245
输出:["agj", "agk", "agl", "ahj", "ahk", "ahl", "aij", "aik", "ail"......
*/
三、解题思路:
我呢是用swift语法来做,但是逻辑思路都是相通的。
第一想到的应该是递归。通过递归,再加上一些判断条件,将对应的字符串加入进数组。1
2
3
4
5
6
7
8
9
10
11
12
13
14// 1.最外围的主方法
func letterCombinations(_ digits: String) -> [String] {
if digits.isEmpty {
return []
}
// 由于swift语法特性,需要将digits字符串包装为一个数组
var strings: [String] = []
for digit in digits {
let str: String = String.init(digit)
strings .append(str)
}
haha(strings,0)
return result
}
1 | // 2.核心代码实现 |
四、小结
有时候这类题都是去找规律,我们需要把一些例子所得到的数据展示出来,然后去寻找规律,让计算的过程直观的表达出来。
注:可以在haha方法里加入一个indexs数组,result也不要限定条件来添加,然后直接在letterCombinations方法里打印出indexs和result的值。这样可以非常直观的查看添加过程。1
2
3
4
5func haha(_ strings: [String], _ index: Int) {
indexs .append(index)
result .append(str)
、、、后面的代码不变
}
耗时12
毫秒,超过100%
的提交记录,总提交数25
。
有任何疑问都可以留言,非常乐意一起探讨。😄