[LeetCode] 784. 字母大小写全排序

题目描述:

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

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

示例 1:

复制代码
输入:s = "a1b2"
输出:["a1b2", "a1B2", "A1b2", "A1B2"]

示例 2:

复制代码
输入: s = "3z4"
输出: ["3z4","3Z4"]

提示:

  • 1 <= s.length <= 12
  • s 由小写英文字母、大写英文字母和数字组成

题目链接:

. - 力扣(LeetCode)

解题主要思路:

其实这题很简单,遍历string中的每个元素,每次遍历的时候分两步走,一步是不需要进行大小写转换,这次直接插入char元素,然后进入下一次遍历;另一步是进行大小写转换,不过需要注意的是,如果在进行大小写转换的时候,发现需要转换的元素是数字的话,那就直接跳过,不需要任何改动,也不需要记录,否则ret中会出现多余的string,因为 "不需要进行大小写转换" 这一步已经帮我们做了该做的事。

解题代码:

cpp 复制代码
class Solution {
public:
    vector<string> ret;
    string path;
    vector<string> letterCasePermutation(string s) {
        dfs(s, 0);
        return ret;
    }
    void dfs(string& s, int pos)
    {
        // 结束条件
        if (path.size() == s.size()) {
            ret.push_back(path);
            return;
        }
        char c = s[pos];
        // 不改变
        path.push_back(c);
        dfs(s, pos+1);
        path.pop_back(); // 回溯

        // 改变
        if (!(c >= '0' && c <= '9')) {
            // 数字的话不用管
            if (c >= 'a' && c <= 'z') c -= 32;
            else c += 32;
            path.push_back(c);
            dfs(s, pos+1);
            path.pop_back();            
        }
    }
};
相关推荐
feilieren11 分钟前
leetcode - 684. 冗余连接
java·开发语言·算法
余~1853816280021 分钟前
矩阵系统源码搭建,OEM贴牌技术
网络·人工智能·线性代数·算法·矩阵
随便取个六字30 分钟前
C++学习:类和对象(二)
c++·学习
Tianwen_Burning31 分钟前
Halcon相机外参自理解
算法
jimmy.hua1 小时前
C++刷怪笼(9)继承
开发语言·c++
OMGmyhair1 小时前
【 C++ 】C++11的初步学习
开发语言·c++·学习
dawn1912282 小时前
Java 中的正则表达式详解
java·开发语言·算法·正则表达式·1024程序员节
黑不拉几的小白兔2 小时前
PTA L1系列题解(C语言)(L1_097 -- L1_104)
数据结构·算法·1024程序员节
南城花随雪。2 小时前
蚁群算法(Ant Colony Optimization)详细解读
算法
秋说2 小时前
【数据结构 | PTA】懂蛇语
数据结构·c++