给定两个由小写字母构成的字符串 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);
}
}复制代码
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
程序员成长的烦恼
吴亮、周金桥、李春雷、周礼 / 华中科技大学出版社 / 2011-4 / 28.00元
还在犹豫该不该转行学编程?还在编程的道路上摸爬滚打?在追寻梦想的道路上你并不孤单,《程序员成长的烦恼》中的四位“草根”程序员也曾有过类似的困惑。看看油田焊接技术员出身的周金桥是如何成功转行当上程序员的,做过钳工、当过外贸跟单员的李春雷是如何自学编程的,打小在486计算机上学习编程的吴亮是如何一路坚持下来的,工作中屡屡受挫、频繁跳槽的周礼是如何找到出路的。 《程序员成长的烦恼》记录了他们一步一......一起来看看 《程序员成长的烦恼》 这本书的介绍吧!