Given a string S, we can transform every letter individually to be lowercase or uppercase to create another string. Return a list of all possible strings we could create.
Examples: Input: S = "a1b2" Output: ["a1b2", "a1B2", "A1b2", "A1B2"] Input: S = "3z4" Output: ["3z4", "3Z4"] Input: S = "12345" Output: ["12345"]
Note:
- Swill be a string with length between- 1and- 12.
- Swill consist only of letters or digits.
A:
class Solution { public: vector<string> letterCasePermutation(string S) { vector<string> res; if(S.length()==0) return res; res.push_back(""); for(char ch:S) { vector<string> newS; vector<char> A; if(isalpha(ch)){ A.push_back(toupper(ch)); A.push_back(tolower(ch)); }else{ A.push_back(ch); } for(auto c:A) { for(auto ss:res) newS.push_back( ss + c); } res = newS; } return res; } };
--------------第二遍  -----------------
class Solution {
public:
    vector<string> letterCasePermutation(string s) {
        vector<string> res;
        vector<char> V(s.begin(), s.end());
        helper(res, V, 0);
        return res;
    }
private:
    void helper(vector<string>& res, vector<char>& V, int start){
        if(start == V.size()){
            string s(V.begin(), V.end());
            res.push_back(s);
            return;
        }
        if(isalpha(V[start])){
            V[start] = toupper(V[start]);
            helper(res, V, start+1);
            V[start] = tolower(V[start]);
            helper(res, V, start+1);
        }else{
            helper(res, V, start+1);
        }
    }
};
No comments:
Post a Comment