穷举vs暴搜vs深搜vs回溯vs剪枝系列一>字母大小写全排列

题目:


解析:


代码:

java 复制代码
private List<String> ret;
    private StringBuffer path;
    public List<String> letterCasePermutation(String s) {
        ret = new ArrayList<>();
        path = new StringBuffer();
        dfs(s,0);
        return ret;
    }

    private void dfs(String s, int pos){
        
        if(pos == s.length()){
            ret.add(path.toString());
            return;
        } 

        char ch = s.charAt(pos);

        //改变
        if(ch < '0' || ch > '9'){
            char tmp = change(ch);
            path.append(tmp);
            dfs(s,pos+1);
            path.deleteCharAt(path.length()-1);//恢复现场
        }

        //不变
        path.append(ch);
        dfs(s,pos+1);
        path.deleteCharAt(path.length()-1);//恢复现场
    }  

    private char change(char ch){
        if(ch >= 'a' && ch <= 'z') return ch -= 32;//小写转大写
        else return ch += 32;//大写转小写
    }
相关推荐
naruto_lnq几秒前
C++中的桥接模式
开发语言·c++·算法
苦藤新鸡几秒前
50.腐烂的橘子
数据结构·算法
想进个大厂6 分钟前
代码随想录day32 动态规划01
算法·动态规划
j4455661119 分钟前
C++中的职责链模式高级应用
开发语言·c++·算法
uesowys22 分钟前
Apache Spark算法开发指导-Decision tree classifier
算法·决策树·spark
池央31 分钟前
贪心算法-最大数
算法·贪心算法
iAkuya37 分钟前
(leetcode)力扣100 57电话号码的字母组合(回溯)
算法·leetcode·深度优先
m0_736919101 小时前
模板元编程性能分析
开发语言·c++·算法
pen-ai1 小时前
【YOLO系列】 YOLOv1 目标检测算法原理详解
算法·yolo·目标检测
2301_765703141 小时前
C++中的职责链模式实战
开发语言·c++·算法