LeetCode每日一题: 亲密字符串(No.859)

栏目: 编程工具 · 发布时间: 6年前

给定两个由小写字母构成的字符串 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就不是亲密字符串。
不相等的字符数等于2A交换这两个字符,再与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);
    }
}复制代码

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

编程精粹

编程精粹

Steve Maguire / 人民邮电出版社 / 2009.2 / 45.00元

编写高质量的、没有bug的程序,是每位程序员所追求的目标。但随着软件规模越来越大,功能日趋复杂,这一目标变得越来越困难。 本书揭示了微软公司应对质量挑战、开发出世界级代码的技术内幕,作者在自己不断探索、实践和思考的基础上,系统总结了多年来指导微软各团队的经验,将其凝聚为许多切实可行的编程实践指导,可谓字字珠玑。正因如此,本书被公认为与《代码大全》齐名的编程技术名著,曾于1993年荣获有软件开......一起来看看 《编程精粹》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

随机密码生成器
随机密码生成器

多种字符组合密码