题目描述
实现函数 ToLowerCase(),该函数接收一个字符串参数 str,并将该字符串中的大写字母转换成小写字母,之后返回新的字符串。
示例 1:
输入: "Hello"
输出: "hello"
示例 2:
输入: "here"
输出: "here"
示例 3:
输入: "LOVELY"
输出: "lovely"
解题思路:
在Java当中,将大写字母字符串转换成小写字母有现成的String类中的方法toLowerCase,可以适用于本题,但是直接调用现成的方法显然不符合我们提升算法思维的初衷,所以我们这里按照常规思路给出解法。
在一个字符串中,将里面的大写字母转换成小写字母,我第一个想到的思路就是遍历字符串中的每个字符,判断当前字符是否为大写字母,如果是大写字母,则将其替换成对应的小写字母,如果当前字符是小写字母,则不作处理。
1、首先将字符串通过toCharArray方法转换成字符数组
2、循环遍历字符数组中的每个字符,判断当前字符是否是大写字母
3、关键的一步在于,如何判断当前字符是大写字母还是小写字母呢?我这里采用了ASCII码的判断方法。由表中得知,大写字母A~Z的对应值为65~90,小写字母a~z的对应值为97~122,大小写字母的差值为32
ASCII值 | 控制字符 | ASCII值 | 控制字符 | ASCII值 | 控制字符 | ASCII值 | 控制字符 |
---|---|---|---|---|---|---|---|
0 | NUT | 32 | (space) | 64 | @ | 96 | 、 |
1 | SOH | 33 | ! | 65 | A | 97 | a |
2 | STX | 34 | " | 66 | B | 98 | b |
3 | ETX | 35 | # | 67 | C | 99 | c |
4 | EOT | 36 | $ | 68 | D | 100 | d |
5 | ENQ | 37 | % | 69 | E | 101 | e |
6 | ACK | 38 | & | 70 | F | 102 | f |
7 | BEL | 39 | , | 71 | G | 103 | g |
8 | BS | 40 | ( | 72 | H | 104 | h |
9 | HT | 41 | ) | 73 | I | 105 | i |
10 | LF | 42 | * | 74 | J | 106 | j |
11 | VT | 43 | + | 75 | K | 107 | k |
12 | FF | 44 | , | 76 | L | 108 | l |
13 | CR | 45 | - | 77 | M | 109 | m |
14 | SO | 46 | . | 78 | N | 110 | n |
15 | SI | 47 | / | 79 | O | 111 | o |
16 | DLE | 48 | 0 | 80 | P | 112 | p |
17 | DCI | 49 | 1 | 81 | Q | 113 | q |
18 | DC2 | 50 | 2 | 82 | R | 114 | r |
19 | DC3 | 51 | 3 | 83 | S | 115 | s |
20 | DC4 | 52 | 4 | 84 | T | 116 | t |
21 | NAK | 53 | 5 | 85 | U | 117 | u |
22 | SYN | 54 | 6 | 86 | V | 118 | v |
23 | TB | 55 | 7 | 87 | W | 119 | w |
24 | CAN | 56 | 8 | 88 | X | 120 | x |
25 | EM | 57 | 9 | 89 | Y | 121 | y |
26 | SUB | 58 | : | 90 | Z | 122 | z |
27 | ESC | 59 | ; | 91 | [ | 123 | { |
28 | FS | 60 | < | 92 | / | 124 | | |
29 | GS | 61 | = | 93 | ] | 125 | } |
30 | RS | 62 | > | 94 | ^ | 126 | ` |
31 | US | 63 | ? | 95 | _ | 127 | DEL |
这样的话就可以将当前字符判断其值是否在65~90之间,如果是的话,那么就为大写字母,将其转换成对应的小写字母只需将其值加32即可。
4、按照第3步将字符数组中的元素全部处理完之后,将其转换成String类型并返回最后结果。
具体代码:
public static String toLowerCase(String str) {
char[] character = str.toCharArray(); // 将字符串转换成字符数组
for (int i = 0; i < character.length; i++) { // 遍历字符数组中的元素
if (character[i] >= 65 && character[i] <= 90) { // 通过ASCII码值判断当前元素是否为大写字母
character[i] = (char) (character[i] + 32); // 如果是大写字母的话将其值加32转换成对应的小写字母
}
}
return String.valueOf(character); // 将字符数组转换成String类型返回结果
}