784.字母大小写全排列
字母大小写全排列
给定一个字符串 s ,通过将字符串 s 中的每个字母转变大小写,我们可以获得一个新的字符串。
返回所有可能得到的字符串集合。以任意顺序返回输出。
示例 1:
输入:s = “a1b2”
输出:[“a1b2”,”a1B2”,”A1b2”,”A1B2”]
示例 2:
输入:s = “3z4”
输出:[“3z4”,”3Z4”]
提示:
- 1 <= s.length <= 12
- s 由小写英文字母、大写英文字母和数字组成
解析
回溯法。遍历字符串,遇到字母时分两种情况递归(保持原样和转换大小写),遇到数字直接跳过。
1 | var letterCasePermutation = function (s) { |
时间复杂度 O(n × 2^k),其中 k 为字母个数,空间复杂度 O(n)。
784.字母大小写全排列
https://leetcode.lz5z.com/784.letter-case-permutation/