-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSolution17.h
86 lines (73 loc) · 2.17 KB
/
Solution17.h
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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
#pragma once
/*
* 17. Letter Combinations of a Phone Number
* Given a string containing digits from 2-9 inclusive, return all possible letter combinations that the number could represent. Return the answer in any order.
A mapping of digit to letters (just like on the telephone buttons) is given below. Note that 1 does not map to any letters.
2 : abc
3 : def
4 : ghi
5 £ºjkl
6 : mno
7 : pqrs
8 : tuv
9 : wxyz
Example 1:
Input: digits = "23"
Output: ["ad","ae","af","bd","be","bf","cd","ce","cf"]
Example 2:
Input: digits = ""
Output: []
Example 3:
Input: digits = "2"
Output: ["a","b","c"]
Constraints:
0 <= digits.length <= 4
digits[i] is a digit in the range ['2', '9'].
*/
class Solution17 {
public:
vector<string> letterCombinations(string digits) {
vector<string> vec_str;
int sz = (int)digits.size();
if (sz == 0) {
// do_nothing
} else if (sz == 1) {
vec_str = num2char[digits[0]];
} else if (sz == 2) {
for (auto& x : num2char[digits[0]]) {
for (auto& y : num2char[digits[1]]) {
vec_str.emplace_back(x + y);
}
}
} else if (sz == 3) {
for (auto& x : num2char[digits[0]]) {
for (auto& y : num2char[digits[1]]) {
for (auto& z : num2char[digits[2]]) {
vec_str.emplace_back(x + y + z);
}
}
}
} else if (sz == 4) {
for (auto& x : num2char[digits[0]]) {
for (auto& y : num2char[digits[1]]) {
for (auto& z : num2char[digits[2]]) {
for (auto& o : num2char[digits[3]]) {
vec_str.emplace_back(x + y + z + o);
}
}
}
}
}
return vec_str;
}
map<char, vector<string>> num2char = {
{'2', {"a","b","c"}},
{'3', {"d","e","f"}},
{'4', {"g","h","i"}},
{'5', {"j","k","l"}},
{'6', {"m","n","o"}},
{'7', {"p","q","r", "s"}},
{'8', {"t","u","v"}},
{'9', {"w","x","y", "z"}},
};
};