Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- public static List<string> get_words_from_phone_number(string phone_number) {
- // Write your code here.
- var phoneRef = new List<List<char>>(){
- new List<char>(){' '},
- new List<char>(){'a','b','c'},
- new List<char>(){'d','e','f'},
- new List<char>(){'g','h','i'},
- new List<char>(){'j','k','l'},
- new List<char>(){'m','n','o'},
- new List<char>(){'p','q','r','s'},
- new List<char>(){'t','u','v'},
- new List<char>(){'w','x','y','z'}
- };
- var results = new List<string>();
- var slate = new List<char>();
- Helper(7,phoneRef,0,slate,results);
- return results;
- }
- public static void Helper(int k, List<List<char>> phoneRef, int currentVal, List<char> slate, List<string> results){
- if(k == 0){
- results.Add(new string(slate.ToArray()).Trim());
- return;
- }
- if(k < 0){
- return;
- }
- int i = currentVal;
- for(int j = 0; j < phoneRef[i].Count;j++){
- slate.Add(phoneRef[i][j]);
- Helper(k-1, phoneRef, i+1, slate, results);
- slate.RemoveAt(slate.Count-1);
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement