LeetCode每日一题——784. 字母大小写全排列

简介: 给定一个字符串 s ,通过将字符串 s 中的每个字母转变大小写,我们可以获得一个新的字符串。

题目

给定一个字符串 s ,通过将字符串 s 中的每个字母转变大小写,我们可以获得一个新的字符串。

返回 所有可能得到的字符串集合 。以 任意顺序 返回输出。

示例

示例 1:

输入:s = “a1b2”

输出:[“a1b2”, “a1B2”, “A1b2”, “A1B2”]

示例 2:

输入: s = “3z4”

输出: [“3z4”,“3Z4”]

提示:

1 <= s.length <= 12

s 由小写英文字母、大写英文字母和数字组成

思路

递归+回溯+set去重

使用递归和回溯可以获得所有可能的结果,然后再利用集合的属性去重即可,这里需注意:只需要对字母进行操作,遇到数字直接跳过。详情看下方题解。

题解

class Solution:
    def letterCasePermutation(self, s: str) -> List[str]:
      # 去重
        ans = set()
        s = list(s)
        n = len(s)
        # 递归函数
        def process(s, index):
          # 每一次调用都加上可能的结果
            ans.add(''.join(s))
            # 从前往后遍历,修改字母元素
            for i in range(index, n):
            # 判断是否字母
             if s[i].isalpha():
                tmp = s[i]
                # 转换大小写
                if s[i].isupper():
                    s[i] = s[i].lower()
                    # 按顺序递归调用
                    process(s, i + 1)
                    s[i] = tmp
                else:
                    s[i] = s[i].upper()
                    # 按顺序递归调用
                    process(s, i + 1)
                    s[i] = tmp  
        process(s, 0)
        return list(ans)
目录
相关文章
|
3月前
|
存储 算法
LeetCode第49题字母异位词分组
LeetCode第49题"字母异位词分组"的解题方法,通过将每个字符串的字符排序后作为键存储在HashMap中,有效地将所有字母异位词分组。
LeetCode第49题字母异位词分组
|
1月前
|
存储
Leetcode第49题(字母异位词分组)
LeetCode第49题要求将字符串数组中的字母异位词分组,可以通过将每个字符串排序后作为键存入哈希表,最后将哈希表中的值添加到结果列表中来实现。
15 1
|
1月前
|
算法
Leetcode第46题(全排列)
这篇文章介绍了LeetCode第46题“全排列”的解题方法,使用深度优先搜索(DFS)和回溯算法来生成给定数组的所有可能排列。
25 0
Leetcode第46题(全排列)
|
1月前
|
算法
Leetcode第十七题(电话号码的字母组合)
这篇文章介绍了如何使用深度优先搜索(DFS)算法来解决LeetCode第17题——电话号码的字母组合问题,通过递归方法生成所有可能的字母组合。
16 0
Leetcode第十七题(电话号码的字母组合)
|
1月前
|
索引
【LeetCode 11】242.有效的字母异位词
【LeetCode 11】242.有效的字母异位词
15 0
【LeetCode 11】242.有效的字母异位词
|
1月前
|
算法
【LeetCode 52】17.电话号码的字母组合
【LeetCode 52】17.电话号码的字母组合
31 0
|
1月前
Leetcode第47题(全排列II)
LeetCode第47题要求返回一个包含重复数字序列的所有不重复全排列,通过深度优先搜索和去重策略来解决。
28 0
|
3月前
|
算法
LeetCode第46题全排列
LeetCode第46题"全排列"的解题方法,利用回溯法避免重复并确保元素的有序性,生成所有可能的排列组合。
LeetCode第46题全排列
|
3月前
|
算法
LeetCode第17题电话号码的字母组合
该文章介绍了 LeetCode 第 17 题电话号码的字母组合的解法,通过分析得出可使用递归和回溯的思想解决,避免循环穷举的高循环次数,并给出了具体的编码实现,同时总结了该题较难理解,需要了解递归的本质,当嵌套循环层次多时可考虑递归。
LeetCode第17题电话号码的字母组合
|
3月前
|
算法
LeetCode第47题全排列II
LeetCode第47题"全排列II"的解题方法,通过排序和添加去重逻辑,使用回溯法避免生成重复的排列组合。