力扣784(java)-字母大小写全排列(中等)
题目:
给定一个字符串 s ,通过将字符串 s 中的每个字母转变大小写,我们可以获得一个新的字符串。
返回 所有可能得到的字符串集合 。以 任意顺序 返回输出。
示例 1:
输入:s = "a1b2"
输出:["a1b2", "a1B2", "A1b2", "A1B2"]
示例 2:
输入: s = "3z4"
输出: ["3z4","3Z4"]
提示:
- 1 <= s.length <= 12
- s 由小写英文字母、大写英文字母和数字组成
来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/letter-case-permutation
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解题思路:
一、用List模拟
有思路,但是写不出来完整的代码
参考@【爪哇缪斯】:https://leetcode.cn/problems/letter-case-permutation/solution/zhua-wa-mou-si-by-muse-77-7jb8/
首先将原字符串 s 放进结果ans中,然后再从头开始遍历字符串 s :
- 当发现下标为 i 处是数字时,就跳过;
- 当发现下标为 i 处是英文字母时,就进行大小写的转换,将本次转换后的整个字符串加入到ans中。
直到i 到达字符串的末尾表示字符串 s 遍历完成,返回ans。结合图进行理解。


java代码:
1 class Solution {
2 public List<String> letterCasePermutation(String s) {
3 List<String> ans = new ArrayList<>();
4 //先将原字符串添加进结果中
5 ans.add(s);
6 //外层循环控制遍历的字符下标
7 for(int i = 0; i < s.length(); i++){
8 //如果是数字就跳过
9 if(s.charAt(i) < 'A') continue;
10 int n = ans.size();
11 //内层循环控制改变的字符串下标
12 for(int j = 0; j < n; j++){
13 char[] cs = ans.get(j).toCharArray();
14 //直接定位在是字符的下标进行大小写转换
15 //将小写转换成大写
16 if(cs[i] >= 'a'){
17 cs[i] = (char)(cs[i] - 32);
18 }else{
19 //将大写转换成小写
20 cs[i] = (char)(cs[i] + 32);
21 }
22 //将本次转换后的字符串加入到结果中
23 ans.add(new String(cs));
24 }
25 }
26 return ans;
27 }
28 }

二、DFS
设计DFS函数为void dfs(char[] cs, List<String> ans, int index),cs为原来字符串s转换成字符数组,ans为当前具体的字符串,index表示当前处理到的字符位置。从前往后遍历每个cs[index],根据cs[index]是否为字母具体讨论:
- 若cs[index]不是字母,则保留,不做任何改变,继续dfs下一个位置 index +1;
- 若cs[index]是字母,则保留原有字母或改变大小写,然后继续dfs下一个位置 index + 1。
当index == n时,说明对原字符串的每一个位置都已经变换完成,直接将当前cs加入到ans中。
注意:
异或:相同为0,不同为1
A 的Ascii 值为65(十进制) 二进制为 01000010
Z 的Ascii 值为90(十进制) 二进制为 01011010
32的二进制值为 00100000
所以可以从大写转小写,从小转大异或运算32,去掉1 也就可以了
举例:
1.c(99):1100011转换成大写,与32(00100000)异或为:1000011(67)为C
2.M(77):01001101转换成小写,与32(00100000)异或为:01101101(109)为m
java代码:
1 class Solution {
2 public List<String> letterCasePermutation(String s) {
3 List<String> ans = new ArrayList<>();
4 char[] cs = s.toCharArray();
5 dfs(cs, ans, 0);
6 return ans;
7 }
8 public void dfs(char[] cs, List<String> ans, int index){
9 if(index == cs.length){
10 ans.add(new String(cs));
11 return;
12 }
13 //不做任何改变继续dfs
14 dfs(cs, ans, index + 1);
15 //改变字母大小写状态
16 if(Character.isLetter(cs[index])){
17 cs[index] ^= 32;
18 dfs(cs, ans, index + 1);
19 }
20 }
21 }

力扣784(java)-字母大小写全排列(中等)的更多相关文章
- Java实现 LeetCode 784 字母大小写全排列(DFS)
784. 字母大小写全排列 给定一个字符串S,通过将字符串S中的每个字母转变大小写,我们可以获得一个新的字符串.返回所有可能得到的字符串集合. 示例: 输入: S = "a1b2" ...
- [LeetCode] 784. 字母大小写全排列 ☆☆☆(回溯、深度优先遍历)
https://leetcode-cn.com/problems/letter-case-permutation/solution/shen-du-you-xian-bian-li-hui-su-su ...
- 领扣(LeetCode)字母大小写全排列 个人题解
给定一个字符串S,通过将字符串S中的每个字母转变大小写,我们可以获得一个新的字符串.返回所有可能得到的字符串集合. 示例: 输入: S = "a1b2" 输出: ["a1 ...
- 784. Letter Case Permutation C++字母大小写全排列
网址:https://leetcode.com/problems/letter-case-permutation/ basic backtracking class Solution { public ...
- [LeetCode] Letter Case Permutation 字母大小写全排列
Given a string S, we can transform every letter individually to be lowercase or uppercase to create ...
- [Swift]LeetCode784. 字母大小写全排列 | Letter Case Permutation
Given a string S, we can transform every letter individually to be lowercase or uppercase to create ...
- Leetcode784.Letter Case Permutation字母大小写全排列
给定一个字符串S,通过将字符串S中的每个字母转变大小写,我们可以获得一个新的字符串.返回所有可能得到的字符串集合. 示例: 输入: S = "a1b2" 输出: ["a1 ...
- Java对字母大小写转换
Java对字母大小写转换 1.小写——大写String aa = "abc".toUpperCase(); 2.大写——小写 String bb = "ABC" ...
- java string 首字母大小写方法
String字符串需要进行首字母大小写改写,查询google,就是将首字母截取,转化大小写 + 首字母后面字符串 //首字母小写 public static String captureName(St ...
- 力扣1689. 十-二进制数的最少数目-C语言实现-中等难度题
题目 传送门 如果一个十进制数字不含任何前导零,且每一位上的数字不是 0 就是 1 ,那么该数字就是一个 十-二进制数 .例如,101 和 1100 都是 十-二进制数,而 112 和 3001 不是 ...
随机推荐
- 关于wine乱码问题的解决方法
在我的百度网盘里面,以及U盘备份,里面的Fonts.zip文件, 使用unzip Fonts.zip----linux指令 把这个文件夹里面的所有文件复制到wine的映射目录里面 cp Fonts/* ...
- git clone error: RPC failed; curl 18 transfer closed with outstanding read data remaining
备忘 git clone比较大的工程时,出现这种错误:error: RPC failed; curl 18 transfer closed with outstanding read data rem ...
- Spring Boot 2.0 新人会踩的坑--启动报404错误
转载自:http://www.javaman.cn/channels/sb2 启动程序,验证效果 根据图示,点击按钮,来启动 Spring Boot Web 程序, 查看控制台输出: . ____ _ ...
- 写了个简单爬虫,分析 Boss 直聘自动驾驶岗位
两年前,朋友想知道 Boss 直聘上关于自动驾驶的岗位有哪些 ,于是,笔者写了一个简单的爬虫 crawler-boss ,将岗位的信息收集起来. 这篇文章,笔者想分享爬虫 crawler-boss 的 ...
- python基础三(数据类型)
一 引子 1 什么是数据? x=10,10是我们要存储的数据 2 为何数据要分不同的类型 数据是用来表示状态的,不同的状态就应该用不同的类型的数据去表示 3 数据类型 数字(整形,长整形,浮点型,复数 ...
- 记录--前端实现电子签名(web、移动端)通用
这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 前言 在现在的时代发展中,从以前的手写签名,逐渐衍生出了电子签名.电子签名和纸质手写签名一样具有法律效应.电子签名目前主要还是在需要个人确 ...
- 记录--教你用three.js写一个炫酷的3D登陆页面
这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 前言: 该篇文章用到的主要技术:vue3.three.js 我们先看看成品效果: 高清大图预览(会有些慢): 座机小图预览: 废话不多说, ...
- Python 合并Excel文件(Excel文件多sheet)
一.Python合并Excel文件多sheet<方法1> import os import pandas as pd # 指定包含Excel文件的文件夹路径 folder_path = ' ...
- vscode中vue代码提示插件
由来 基于(Vue 3 Snippets,Vue VSCode Snippets)插件集成而来,因为这俩插件目前没有集成最新vue代码片段,且集成内容相对较少,于是这个插件就诞生了 插件提示跟vue写 ...
- vue初学核心基础
一.初识vue 1.vue的使用 导入vue之后创建vue模块,el属性表示控制区域的id名称,data表示该区域内的数据 在vue中我们都是用表中模板的标准语法来传递数据 <head> ...