题目:
解析:
代码:
javaprivate 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;//大写转小写 }
穷举vs暴搜vs深搜vs回溯vs剪枝系列一>字母大小写全排列
robin_suli2025-01-10 14:10
相关推荐
Ch_ty5 分钟前
leetcode解题思路分析(一百六十八)1452 - 1458 题哼?~6 分钟前
算法学习--离散化AI科技星13 分钟前
引力编程时代:人类文明存续与升维Blossom.1186 小时前
移动端部署噩梦终结者:动态稀疏视觉Transformer的量化实战轻微的风格艾丝凡6 小时前
卷积的直观理解田梓燊8 小时前
红黑树分析 1晚风吹长发9 小时前
二分查找算法+题目详解悠悠~飘9 小时前
18.PHP基础-递归递推算法pilgrim539 小时前
结合 Leetcode 题探究KMP算法罗义凯10 小时前
其中包含了三种排序算法的注释版本(冒泡排序、选择排序、插入排序),但当前只实现了数组的输入和输出功能。
