题目:亲密字符串
给定两个由小写字母构成的字符串 A 和 B 。
只要咱们能够经过交换 A 中的两个字母获得与 B 相等的结果,就返回 true ;不然返回 false 。
复制代码
示例:
输入: A = "ab", B = "ba"
输出: true
输入: A = "ab", B = "ab"
输出: false
输入: A = "aa", B = "aa"
输出: true
输入: A = "aaaaaaabc", B = "aaaaaaacb"
输出: true
输入: A = "", B = "aa"
输出: false
复制代码
思考:
这道题首先判断两个字符串长度是否相等,长度不相等不多是亲密字符串。
长度相等时,再比较两个字符串是否相等。
两个字符串相等:则查找在A或者B中是否有相同字符出现,有则是亲密字符串,没有就不是亲密字符串。
两个字符串不相等:先遍历记录不相等的字符个数和位置。不相等的字符数不等于2就不是亲密字符串。
不相等的字符数等于2:A交换这两个字符,再与B比较,相等就是亲密字符串。
复制代码
实现:
class Solution {
public boolean buddyStrings(String A, String B) {
//比较长度
if (A.length() != B.length()) {
return false;
}
//字符串是否相等
if (A.equals(B)) {
//相等判断是否有重复字符
for (int count = 0; count < A.length(); count++) {
if (A.indexOf(A.charAt(count), count + 1) != -1) {
//有重复字符返回true
return true;
}
}
//没有返回false
return false;
} else {//字符串不相等
//记录不相等字符出现次数
int time = 0;
//记录不相等字符位置
List<Integer> pos = new ArrayList<>();
for (int count = 0; count < A.length(); count++) {
if (A.charAt(count) != B.charAt(count)) {
time++;
pos.add(count);
}
}
//次数不等于2 不是亲密字符串
if (time !=2) {
return false;
} else {
//等于2交换字符后再次比较
return swap(A, pos.get(0), pos.get(1)).equals(B);
}
}
}
private String swap(String str, Integer pos1, Integer pos2) {
char[] charArray = str.toCharArray();
char temp = charArray[pos1];
charArray[pos1] = charArray[pos2];
charArray[pos2] = temp;
return new String(charArray);
}
}复制代码