LeetCode每日一题: 同构字符串(No.205)

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

给定两个字符串 s  t,判断它们是否是同构的。
如果 s 中的字符可以被替换得到 t ,那么这两个字符串是同构的。
所有出现的字符都必须用另一个字符替换,同时保留字符的顺序。两个字符不能映射到同一个字符上,但字符可以映射自己本身。
复制代码

示例:

输入: s = "egg", t = "add"
输出: true

输入: s = "foo", t = "bar"
输出: false

输入: s = "paper", t = "title"
输出: true
复制代码

思考:

这道题主要是要判断两个字符串相同位置字符的对应关系。
用两个HashMap来保存这种对应关系,map1存放s中字符与t中相同位置字符对应关系,map2存放t中字符与s中相同位置字符对应关系。
循环取得两个字符串中相同位置的字符c1,c2,在map1中寻找keyc1value,若没找到就将c1c2作为keyvalue加入map1
map1找到keyc1value则与c2比较,不相等则不为同构,相等就继续向下。
同样在map2中寻找keyc2value,若没找到就将c2c1作为keyvalue加入map2
map2找到keyc2value则与c1比较,不相等则不为同构,相等就继续向下。
循环结束后没有中途return即为同构字符串返回true
复制代码

实现:

class Solution {
    public boolean isIsomorphic(String s, String t) {
        Map<Character, Character> map1 = new HashMap<>();
        Map<Character, Character> map2 = new HashMap<>();
        for (int count = 0; count < s.length(); count++) {
            char c1 = s.charAt(count);
            char c2 = t.charAt(count);
            if (map1.containsKey(c1)) {
                if (map1.get(c1) != c2) return false;
            } else {
                map1.put(c1, c2);
            }
            if (map2.containsKey(c2)) {
                if (map2.get(c2) != c1) return false;
            } else {
                map2.put(c2, c1);
            }
        }
        return true;
    }
}复制代码

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

查看所有标签

猜你喜欢:

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

C++程序设计原理与实践

C++程序设计原理与实践

(美)Bjarne Stroustrup / 王刚 等 / 机械工业出版社 / 2010.7 / 108.00元

本书是经典程序设计思想与C++开发实践的完美结合,是C++之父回归校园后对C++编程原理和技巧的全新阐述。书中全面地介绍了程序设计基本原理,包括基本概念、设计和编程技术、语言特性以及标准库等,教你学会如何编写具有输入、输出、计算以及简单图形显示等功能的程序。此外,本书通过对C++思想和历史的讨论、对经典实例(如矩阵运算、文本处理、测试以及嵌入式系统程序设计)的展示,以及对C语言的简单描述,为你呈现......一起来看看 《C++程序设计原理与实践》 这本书的介绍吧!

URL 编码/解码
URL 编码/解码

URL 编码/解码

SHA 加密
SHA 加密

SHA 加密工具

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

Markdown 在线编辑器