LeetCode(40)同构字符串【哈希表】【简单】

LeetCode(40)同构字符串【哈希表】【简单】_第1张图片

目录

    • 1.题目
    • 2.答案
    • 3.提交结果截图

链接: 同构字符串

1.题目

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

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

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

示例 1:

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

示例 2:

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

示例 3:

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

提示:

  • 1 <= s.length <= 5 * 10^4
  • t.length == s.length
  • st 由任意有效的 ASCII 字符组成

2.答案

class Solution {
    public boolean isIsomorphic(String s, String t) {
        Map<Character, Character> map = new HashMap<>();
        Set<Character> set = new HashSet<>();
        for (int i = 0; i < s.length(); i++) {
            boolean isNewS = !map.containsKey(s.charAt(i));
            boolean isNewT = !set.contains(t.charAt(i));
            // 新增、已存在保持一致
            if (!Objects.equals(isNewS, isNewT)) {
                return false;
            }
            if (isNewS) {
                // 新增
                map.put(s.charAt(i), t.charAt(i));
                set.add(t.charAt(i));
            } else if (!Objects.equals(map.get(s.charAt(i)), t.charAt(i))) {
                // 已存在但与之前映射不同
                return false;
            }
        }
        return true;
    }
}

3.提交结果截图

LeetCode(40)同构字符串【哈希表】【简单】_第2张图片

整理完毕,完结撒花~

你可能感兴趣的:(LeetCode,leetcode,散列表,算法)