709.转换成小写字母

2020-08-20  本文已影响0人  一角钱技术

709.转换成小写字母

实现函数 ToLowerCase(),该函数接收一个字符串参数 str,并将该字符串中的大写字母转换成小写字母,之后返回新的字符串。

示例 1:
输入: "Hello"
输出: "hello"

示例 2:
输入: "here"
输出: "here"

示例 3:
输入: "LOVELY"
输出: "lovely"

方法1:ASCCII码

思路:

通过 ASCII 码表操作字符串即可。
a-z:97-122
A-Z:65-90
0-9:48-57

参考代码1:

class Solution {
    public String toLowerCase(String str) {
        if (str == null || str.length() == 0) {
            return str;
        }
        StringBuilder sb = new StringBuilder();
        for (char ch : str.toCharArray()) {
            // a-z:97-122  A-Z:65-90  0-9:48-57
            if (ch >= 'A' && ch <= 'Z') {
                sb.append((char)(ch + 32));
            } else {
                sb.append(ch);
            }
        }
        return sb.toString();
    }
}

参考代码2:

class Solution {
    public String toLowerCase(String str) {
        if (str == null || str.length() == 0) {
            return str;
        }
        char[] ch = str.toCharArray();
        for (int i = 0; i < str.length(); i++) {
            if (ch[i] >= 'A' && ch[i] <= 'Z') {
                ch[i] += 32;
            }
        }
        return String.valueOf(ch);
    }
}

方法2:位运算

思路:

用位运算的技巧:

SCII码表中大写的A是65,小写的a是97,它们的差是32
65 | 32 转为二进制(按8位来算)可以得到
0100 0001 | 0010 0000 = 0110 0001 = 97 = a

参考代码3:

class Solution {
    public String toLowerCase(String str) {
        if (str == null || str.length() == 0) {
            return str;
        }
        char[] ch = str.toCharArray();
        for (int i = 0; i < str.length(); i++) {
            ch[i] |= 32;
        }
        return String.valueOf(ch);
    }
}
部分图片来源于网络,版权归原作者,侵删。
上一篇下一篇

猜你喜欢

热点阅读