forked from mandliya/algorithms_and_data_structures
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdialpad_combinations.cpp
80 lines (74 loc) · 2.41 KB
/
dialpad_combinations.cpp
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
/*
* You are given a digit string (e.g "1234", "567" etc),
* provide all possible letter combinations we could generate from this digit string,
* based on the mapping we see on the telphone/mobile dialpad.
* If you have typed SMS in old style phones, you would know. For e.g. "1" is mapped to "abc",
* 2 is mapped to "def".
* Example: "34" will give output: {"dg","dh","di","eg","eh","ei","fg","fh","fi"}
* Note that order does not matter in result set.
*
* Approach:
*
* We can use a simple backtracking approach. Since each digit letter could be mapped to multiple characters,
* for example '1' is mapped to 'a', 'b' and 'c'. As we move along in the digit string, for an index i, we will
* add all possible letters to the string and recursively move ahead to i+1,
* i.e. we will choose say 'a' as our choice for the iteration, we map '1' to 'a' and then move to next
* digit letter (i+1) and recurse, then we will make 'b' as our choice for position i, and then 'c'
* This way we do it for all the letters at all the positions.
* The idea is to generate all possible subsets of the string, keeping in mind the order.
*/
#include <iostream>
#include <string>
#include <unordered_map>
#include <vector>
std::unordered_map<char, std::string> dict {
{'1' , "" },
{'2' , "abc"},
{'3' , "def"},
{'4' , "ghi"},
{'5' , "jkl"},
{'6' , "mno"},
{'7' , "pqrs"},
{'8' , "tuv"},
{'9' , "wxyz"},
{'0' , " "},
{'*' , "*"},
{'#' , "#"}
};
void helper(const std::string& digits, std::string rs,
std::vector<std::string>& result, int index)
{
if (index == digits.length()) {
result.push_back(rs);
return;
}
char c = digits[index];
std::string ps = dict[c];
for (int i = 0; i < ps.length(); ++i) {
helper(digits, rs + ps[i], result, index + 1);
}
}
std::vector<std::string> letter_combinations(const std::string& digits)
{
std::vector<std::string> result;
if (digits.size() == 0) {
return result;
}
std::string rs("");
helper(digits, rs, result, 0);
return result;
}
void print_vec(const std::vector<std::string>& vec)
{
for(auto v: vec) {
std::cout << v << " ";
}
std::cout << std::endl;
}
int main()
{
std::string digits{"34"};
std::cout << "All possible combinations of digits " << digits << " are: \n";
print_vec(letter_combinations(digits));
return 0;
}