Shanshan Pythoner Love CPP

Leetcode 17 Letter Combinations of a Phone Number

2016-07-29

Letter Combinations of a Phone Number

Given a digit string, return all possible letter combinations that the number could represent.

A mapping of digit to letters (just like on the telephone buttons) is given below.

Input:Digit string “23”

Output: [“ad”, “ae”, “af”, “bd”, “be”, “bf”, “cd”, “ce”, “cf”].

class Solution {
public:
    vector<string> letterCombinations(string digits) {
        vector<string> res;
        if (digits.empty()) return res;
        vector<string> table = {"", "", "abc", "def", "ghi", "jkl","mno", "pqrs","tuv","wxyz"};
        helper(digits, table, 0, "", res);
        return res;
    }
    
    void helper(string digits, vector<string> table, int pos, string curr, vector<string> &res) {
        if (pos == digits.size()) {
            res.push_back(curr);
            return;
        }
        
        for (int i=0; i<table[digits[pos]-'0'].size(); i++) {
            helper(digits, table, pos+1, curr+table[digits[pos]-'0'][i], res);
        }
    }
};

Similar Posts

Comments

Content