同构字符串
给定两个字符串 s
和 t
,判断它们是否是同构的。
如果 s
中的字符可以按某种映射关系替换得到 t
,那么这两个字符串是同构的。
每个出现的字符都应当映射到另一个字符,同时不改变字符的顺序。不同字符不能映射到同一个字符上,相同字符只能映射到同一个字符上,字符可以映射到自己本身。
示例 1:
输入:s ="egg"
, t ="add"
输出:true
示例 2:
输入:s ="foo"
, t ="bar"
输出:false
示例 3:
输入:s ="paper"
, t ="title"
输出:true
提示:
1 <= s.length <= 5 * 104
t.length == s.length
s
和t
由任意有效的 ASCII 字符组成
class Solution {
public:
bool isIsomorphic(string s, string t) {
map<char,char>mymap,eymap;
for(int size=0;size<s.length();size++){
if(mymap.count(t[size])&&mymap[t[size]]!=s[size])
return false;
if(!mymap.count(t[size]))
if(!eymap.count(s[size]))mymap[t[size]]=s[size],eymap[s[size]]=t[size];
else return false;
}
return true;
}
};
原文地址:https://blog.csdn.net/2303_76711142/article/details/143824560
免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!