[Java][Leetcode simple] 205. 同构字符串

法1: 单哈希表

  • 遍历s,如果sc不在map中,需要添加映射关系。(此时,要排除多对一的关系:例如:bacd,baba;此时b已经被b映射了,就不能再映射到d上 )
  • 如果sc在map中,此时说明已经添加过映射关系了,此时取出当时的映射关系,如果与tc不相等,说明本次的映射关系错误
java 复制代码
class Solution {
    public boolean isIsomorphic(String s, String t) {
         if(s.length() != t.length()) return false;
         int n = s.length();
         Map<Character,  Character> map = new HashMap<>();
         for(int i = 0;i< n ;i++){
              char sc = s.charAt(i);
              char tc = t.charAt(i);
               if(!map.containsKey(sc)){
                    if(map.containsValue(tc)) return false;
                    map.put(sc, tc);
               }else{
                   char tmp = map.get(sc);
                   if(tmp != tc) return false;
               }
         }
         return true;
    }
}

法2:官解:双数组字符映射

哈希表map.containsValue o(K) 还是有点耗时,采用两个数组分别记录映射关系。

java 复制代码
class Solution {
    public boolean isIsomorphic(String s, String t) {
        if(s.length() != t.length()) return false;
        int n = s.length();
        int[] mapS = new int[256]; 
        int[] mapT = new int[256]; 
        for(int i = 0;i<n ;i++){
            char c1 = s.charAt(i);
            char c2 = t.charAt(i);
            if(mapS[c1] != 0 &&  mapS[c1] != c2 ) return false;
            if(mapT[c2] != 0 &&  mapT[c2] != c1 ) return false;

            mapS[c1] = c2;
            mapT[c2] = c1;
        }
        return true;
    }
}
相关推荐
洛水水6 分钟前
【力扣100题】81.寻找两个正序数组的中位数
数据结构·算法·leetcode
终将老去的穷苦程序员7 分钟前
基于SpringBoot的餐饮管理系统
java·spring boot·后端
心之伊始9 分钟前
Spring AI Tool Calling 实战:让 Java Agent 调用本地 Bean 工具方法
java·spring boot·agent·spring ai·tool calling
AI人工智能+电脑小能手14 分钟前
【大白话说Java面试题 第110题】【并发篇】第10题:CAS 存在哪些问题?
java·开发语言·面试
瀚高PG实验室32 分钟前
java中间件无法连接数据库
java·数据库·中间件·瀚高数据库
happymaker062635 分钟前
LeetCodeHot100——155.最小栈
算法
东南门吹雪35 分钟前
JAVA TCP socket编程框架
java·高并发·socket·tcp·nio
xingyuzhisuan36 分钟前
缓存命中率提升方案:从 30% 优化至 82% 全流程优化记录
java·开发语言·缓存·ai
洛水水1 小时前
【力扣100题】85.每日温度
算法·leetcode·职场和发展
一条泥憨鱼1 小时前
Java开发效率神器:Lombok从入门到精通!
java·后端·学习·开发·lombok