力扣(LeetCode)算法_C++——同构字符串

给定两个字符串 s 和 t ,判断它们是否是同构的。

如果 s 中的字符可以按某种映射关系替换得到 t ,那么这两个字符串是同构的。

每个出现的字符都应当映射到另一个字符,同时不改变字符的顺序。不同字符不能映射到同一个字符上,相同字符只能映射到同一个字符上,字符可以映射到自己本身。

示例 1:

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

输出:true

示例 2:

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

输出:false

示例 3:

输入:s = "paper", t = "title"

输出:true

cpp 复制代码
bool isIsomorphic(string s, string t)
{
    unordered_map<char, char> f;
    unordered_map<char, char> g;
    int n = s.size();
    for (int i = 0; i < n; i++)
    {
        if (f.find(s[i]) != f.end() || g.find(t[i]) != g.end())
        {
            if (f[s[i]] != t[i] || g[t[i]] != s[i])
                return false;
        }
        else
        {
            f[s[i]] = t[i];
            g[t[i]] = s[i];
        }
    }
    return true;
}```

 
相关推荐
qq_416018727 分钟前
分布式缓存一致性
开发语言·c++·算法
CoovallyAIHub12 分钟前
多 Agent 手术推理框架:Agent 辩论+RAG 补上手术知识,零样本超越监督基线 14.6 个百分点
算法·架构·机器人
干啥啥不行,秃头第一名15 分钟前
STL容器内部实现剖析
开发语言·c++·算法
Zarek枫煜15 分钟前
zig与c3的冒泡排序算法
算法
xiaoye-duck19 分钟前
《算法题讲解指南:动态规划算法--简单多状态dp问题》--13.删除并获得点数,14.粉刷房子
c++·算法·动态规划
老鼠只爱大米20 分钟前
LeetCode经典算法面试题 #347:前 K 个高频元素(最小堆、桶排序、快速选择等多种实现方案详解)
算法·leetcode·堆排序·java面试题·桶排序·快速选择·topk
2401_8318249622 分钟前
内存泄漏检测与防范
开发语言·c++·算法
FluxMelodySun33 分钟前
机器学习(二十五) 降维:主成分分析(PCA)及特征值分解
人工智能·算法·机器学习
liuyao_xianhui1 小时前
优选算法_分治_快速排序_归并排序_C++
开发语言·数据结构·c++·算法·leetcode·排序算法·动态规划
爱丽_2 小时前
ThreadLocal 机制:弱引用 Entry、内存泄漏、线程池复用与线上排查
java·jvm·算法