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)
目录
相关文章
|
27天前
|
存储 算法
LeetCode第49题字母异位词分组
LeetCode第49题"字母异位词分组"的解题方法,通过将每个字符串的字符排序后作为键存储在HashMap中,有效地将所有字母异位词分组。
LeetCode第49题字母异位词分组
|
27天前
|
算法
LeetCode第46题全排列
LeetCode第46题"全排列"的解题方法,利用回溯法避免重复并确保元素的有序性,生成所有可能的排列组合。
LeetCode第46题全排列
|
27天前
|
算法
LeetCode第17题电话号码的字母组合
该文章介绍了 LeetCode 第 17 题电话号码的字母组合的解法,通过分析得出可使用递归和回溯的思想解决,避免循环穷举的高循环次数,并给出了具体的编码实现,同时总结了该题较难理解,需要了解递归的本质,当嵌套循环层次多时可考虑递归。
LeetCode第17题电话号码的字母组合
|
27天前
|
算法
LeetCode第47题全排列II
LeetCode第47题"全排列II"的解题方法,通过排序和添加去重逻辑,使用回溯法避免生成重复的排列组合。
|
1月前
|
Python
【Leetcode刷题Python】46. 全排列
本文介绍了LeetCode题目46的Python编程解决方案,题目要求给定一个不含重复数字的数组,返回该数组所有可能的全排列。
16 0
|
3月前
|
算法 容器
【LeetCode刷题】滑动窗口解决问题:水果成篮、找到字符串中所有字母异位词
【LeetCode刷题】滑动窗口解决问题:水果成篮、找到字符串中所有字母异位词
|
3月前
|
存储
力扣经典150题第四十二题:字母异位词分组
力扣经典150题第四十二题:字母异位词分组
19 0
|
3月前
|
存储
力扣经典150题第四十一题:有效的字母异位词
力扣经典150题第四十一题:有效的字母异位词
16 0
|
3月前
|
算法
【经典LeetCode算法题目专栏分类】【第11期】递归问题:字母大小写全排列、括号生成
【经典LeetCode算法题目专栏分类】【第11期】递归问题:字母大小写全排列、括号生成
|
1月前
|
Python
【Leetcode刷题Python】剑指 Offer 32 - III. 从上到下打印二叉树 III
本文介绍了两种Python实现方法,用于按照之字形顺序打印二叉树的层次遍历结果,实现了在奇数层正序、偶数层反序打印节点的功能。
38 6