-
Notifications
You must be signed in to change notification settings - Fork 277
/
Copy pathLCP.java
35 lines (29 loc) · 911 Bytes
/
LCP.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
class Solution {
public List<String> letterCombinations(String digits) {
String[] set = new String[10];
set[2] = "abc";
set[3] = "def";
set[4] = "ghi";
set[5] = "jkl";
set[6] = "mno";
set[7] = "pqrs";
set[8] = "tuv";
set[9] = "wxyz";
List<String> ans = new ArrayList<>();
if(digits == null || digits.length()==0){
return ans;
}
helper(ans, digits, set, 0, "");
return ans;
}
private void helper(List<String> ans, String digits, String[] set, int index, String currString){
if(index == digits.length()){
ans.add(currString);
return ;
}
String possibleChars = set[digits.charAt(index) - '0'];
for(char c: possibleChars.toCharArray()){
helper(ans, digits, set, index+1, currString + c);
}
}
}