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)
目录
相关文章
|
存储 算法
LeetCode第49题字母异位词分组
LeetCode第49题"字母异位词分组"的解题方法,通过将每个字符串的字符排序后作为键存储在HashMap中,有效地将所有字母异位词分组。
LeetCode第49题字母异位词分组
|
存储 算法 Go
【LeetCode 热题100】17:电话号码的字母组合(详细解析)(Go语言版)
LeetCode 17题解题思路采用回溯算法,通过递归构建所有可能的组合。关键点包括:每位数字对应多个字母,依次尝试;递归构建下一个字符;递归出口为组合长度等于输入数字长度。Go语言实现中,使用map存储数字到字母的映射,通过回溯函数递归生成组合。时间复杂度为O(3^n * 4^m),空间复杂度为O(n)。类似题目包括括号生成、组合、全排列等。掌握回溯法的核心思想,能够解决多种排列组合问题。
515 11
|
存储
Leetcode第49题(字母异位词分组)
LeetCode第49题要求将字符串数组中的字母异位词分组,可以通过将每个字符串排序后作为键存入哈希表,最后将哈希表中的值添加到结果列表中来实现。
195 1
|
算法
Leetcode第46题(全排列)
这篇文章介绍了LeetCode第46题“全排列”的解题方法,使用深度优先搜索(DFS)和回溯算法来生成给定数组的所有可能排列。
323 0
Leetcode第46题(全排列)
|
算法
Leetcode第十七题(电话号码的字母组合)
这篇文章介绍了如何使用深度优先搜索(DFS)算法来解决LeetCode第17题——电话号码的字母组合问题,通过递归方法生成所有可能的字母组合。
225 0
Leetcode第十七题(电话号码的字母组合)
|
索引
【LeetCode 11】242.有效的字母异位词
【LeetCode 11】242.有效的字母异位词
180 0
【LeetCode 11】242.有效的字母异位词
|
算法
【LeetCode 52】17.电话号码的字母组合
【LeetCode 52】17.电话号码的字母组合
206 0
Leetcode第47题(全排列II)
LeetCode第47题要求返回一个包含重复数字序列的所有不重复全排列,通过深度优先搜索和去重策略来解决。
157 0
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
430 6
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
搜索推荐 索引 Python
【Leetcode刷题Python】牛客. 数组中未出现的最小正整数
本文介绍了牛客网题目"数组中未出现的最小正整数"的解法,提供了一种满足O(n)时间复杂度和O(1)空间复杂度要求的原地排序算法,并给出了Python实现代码。
521 2

热门文章

最新文章