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

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

给定两个由小写字母构成的字符串 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);
    }
}复制代码

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

查看所有标签

猜你喜欢:

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

Python 3面向对象编程

Python 3面向对象编程

[加]Dusty Phillips(达斯帝•菲利普斯) / 肖鹏、常贺、石琳 / 电子工业出版社 / 2015-6 / 79.00元

Python 是一种面向对象的解释型语言,面向对象是其非常重要的特性。《Python 3面向对象编程》通过Python 的数据结构、语法、设计模式,从简单到复杂,从初级到高级,一步步通过例子来展示了Python 中面向对象的概念和原则。 《Python 3面向对象编程》不是Python 的入门书籍,适合具有Python 基础经验的开发人员阅读。如果你拥有其他面向对象语言的经验,你会更容易理解......一起来看看 《Python 3面向对象编程》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器