给定两个字符串 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) {
if(s.size() != t.size()){ return false;}
unordered_map<char,char> smap;
unordered_map<char,char> tmap;
for(int i = 0; i < s.size(); i++)
{
if (smap.find(s[i]) == smap.end())
{
smap[s[i]] = t[i];
}
if(tmap.find(t[i]) == tmap.end())
{
tmap[t[i]] = s[i];
}
if(smap[s[i]] != t[i] || tmap[t[i]] != s[i])
{
return false;
}
}
return true;
}
};
思路:
用smap和tmap分别记录s[i]到t[i]和t[i]到s[i]的映射关系。
如果samp中不存在s[i],就建立s[i]到t[i]的映射关系;如果tmap中不存在t[i],就建立t[i]到s[i]的映射关系。
如果存在不同的映射关系,就返回false。