找不同
题目:
给定两个字符串 s 和 t,它们只包含小写字母。
字符串 t 由字符串 s 随机重排,然后在随机位置添加一个字母。
请找出在 t 中被添加的字母。
示例 1:
输入:s = "abcd", t = "abcde"
输出:"e"
解释:'e' 是那个被添加的字母。
示例 2:
输入:s = "", t = "y"
输出:"y"
示例 3:
输入:s = "a", t = "aa"
输出:"a"
示例 4:
输入:s = "ae", t = "aea"
输出:"a"
解题思路:先将字符串转换成字符数组之后对数组进行排序比较即可
class Solution {
public char findTheDifference(String s, String t) {
if(s.isEmpty()) {
return t.charAt(0);
}
char[] cs = s.toCharArray(), ct = t.toCharArray();
Arrays.sort(cs);
Arrays.sort(ct);
for(int i = 0; i < cs.length; i++) {
if(cs[i] != ct[i]) {
return ct[i];
}
}
return ct[ct.length - 1];
}
}
另一种思路:转换成字符数组和分别进行求和,两数之差就是添加的字符
class Solution {
public char findTheDifference(String s, String t) {
if(s.isEmpty()) {
return t.charAt(0);
}
char[] cs = s.toCharArray(), ct = t.toCharArray();
int sumS = 0, sumT = 0;
for(char c : cs) {
sumS += c;
}
for(char c : ct) {
sumT += c;
}
return (char)(sumT - sumS);
}
}