[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;
    }
}
相关推荐
多加点辣也没关系1 小时前
设计模式-策略模式
java·设计模式·策略模式
智者知已应修善业1 小时前
【51单片机独立按键控制数码管自增自减】2023-10-5
c++·经验分享·笔记·算法·51单片机
2601_953660371 小时前
Java Map集合详解与实战
java·开发语言·python
2301_800895101 小时前
第十四届蓝桥杯国赛b组真题---备战国赛版h
算法·蓝桥杯·深度优先
星晨羽1 小时前
java通过共享目录协议下载文件到本地
java
YuanDaima20481 小时前
云计算基础与容器技术演进
java·服务器·人工智能·python·深度学习·云计算·个人开发
java1234_小锋2 小时前
SpringBoot可以同时处理多少请求?
java·spring boot·后端
生信之灵2 小时前
告别模板配准:LAMNr Flow如何用一次求逆破解多模态解剖对齐难题
人工智能·算法
焜昱错眩..2 小时前
力扣周赛难题 3906.统计网格路径中好整数的数目——自我拆解学习与分析(数位dp上下界的奇妙)
学习·算法·leetcode·动态规划