「这是我参与2022首次更文挑战的第36天,活动详情查看:2022首次更文挑战」。
题目描述:
709. 转换成小写字母 - 力扣(LeetCode) (leetcode-cn.com)
给你一个字符串 s
,将该字符串中的大写字母转换成相同的小写字母,返回新的字符串。
示例一
输入: s = "Hello"
输出: "hello"
示例二
输入: s = "here"
输出: "here"
示例三
输入: s = "here"
输出: "here"
提示:
1 <= s.length <= 100
s
由 ASCII 字符集中的可打印字符组成
思路分析
使用SDK
这个没什么好说的,一般的SDK都有toLowerCase()这种类似的函数,直接调用就行了呗。
这个太简单,就不贴代码了。
位运算
这个看了一个题解评论之后学到的。
学习位运算
大写变小写、小写变大写 : 字符 ^= 32;
大写变小写、小写变小写 : 字符 |= 32;
小写变大写、大写变大写 : 字符 &= -33;
ASCCII码
通过 ASCII 码表操作字符串即可:SCII码表中大写的A是65,小写的a是97,它们的差是32
a-z:97-122
A-Z:65-90
0-9:48-57
所以我们只要找到大写字母然后+32即可。
自行实现转小学api
这个直接看官解就好了,讲的还是很详细的。
AC代码
class Solution {
fun toLowerCase(s: String): String {
val offset = 'A' - 'a'
val chars = s.toCharArray()
for (index in chars.indices) {
if (chars[index] in 'A'..'Z') {
chars[index] = chars[index] - offset
}
}
return String(chars)
}
}
总结
这一题相对来说还是蛮简单的,很容易就想到多种方法,但是要自行设计也给api还是需要考虑一点东西的。
参考
转换成小写字母 - 转换成小写字母 - 力扣(LeetCode) (leetcode-cn.com)