[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();            
        }
    }
};
相关推荐
飞鸿踏雪(蓝屏选手)4 小时前
137 ≤ Chrome 主密钥获取研究
c++·chrome·windows·网络安全·逆向分析
洛水水4 小时前
【力扣100题】18.随机链表的复制
算法·leetcode·链表
南宫萧幕5 小时前
规则基 EMS 仿真实战:SOC 区间划分与 Simulink 闭环建模全解
算法·matlab·控制
爱滑雪的码农5 小时前
Java基础十七:数据结构
数据结构
多加点辣也没关系5 小时前
数据结构与算法|第二十三章:高级数据结构
数据结构·算法
孬甭_7 小时前
初识数据结构与算法
数据结构
hoiii1877 小时前
孤立森林 (Isolation Forest) 快速异常检测系统
算法
c++之路8 小时前
适配器模式(Adapter Pattern)
java·算法·适配器模式
吴声子夜歌9 小时前
Java——接口的细节
java·开发语言·算法
myheartgo-on9 小时前
Java—方 法
java·开发语言·算法·青少年编程