给定两个字符串 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中寻找key为c1的value,若没找到就将c1、c2作为key、value加入map1。 若map1找到key为c1的value则与c2比较,不相等则不为同构,相等就继续向下。 同样在map2中寻找key为c2的value,若没找到就将c2、c1作为key、value加入map2。 若map2找到key为c2的value则与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; } }复制代码
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- LeetCode - 205 - 同构字符串(isomorphic-strings)
- react同构实践——实现自己的同构模板
- 如何构建一个WEB同构应用
- React Native 三端同构实战
- React服务端渲染(前后端路由同构)
- React 中同构(SSR)原理脉络梳理
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
极简算法史:从数学到机器的故事
[法] 吕克•德•布拉班迪尔 / 任轶 / 人民邮电出版社 / 2019-1 / 39.00元
数学、逻辑学、计算机科学三大领域实属一家,彼此成就,彼此影响。从古希腊哲学到“无所不能”的计算机,数字、计算、推理这些貌似简单的概念在三千年里融汇、碰撞。如何将逻辑赋予数学意义?如何从简单运算走向复杂智慧?这背后充满了人类智慧的闪光:从柏拉图、莱布尼茨、罗素、香农到图灵都试图从数学公式中证明推理的合理性,缔造完美的思维体系。他们是凭天赋制胜,还是鲁莽地大胆一搏?本书描绘了一场人类探索数学、算法与逻......一起来看看 《极简算法史:从数学到机器的故事》 这本书的介绍吧!