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:
S
will be a string with length between1
and12
.S
will 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