day22(12.2)——leetcode面试经典150

290. 单词规律

290. 单词规律

题目:

题解:

java 复制代码
class Solution {
    public boolean wordPattern(String pattern, String s) {
        //得到每个单词
        List<String> ss = Arrays.asList(s.split(" "));
        Map<Character,String> map1 = new HashMap<>();
        Map<String,Character> map2 = new HashMap<>();
        if(ss.size() != pattern.length()) {
            return false;
        }
        for(int i=0;i<pattern.length();i++) {
            Character c = pattern.charAt(i);
            //将pattern作为key
            //如果在map1中包含c
            if(map1.containsKey(c)) {
                //如果对应的字符串不是当前的字符串,直接返回false
                if(!map1.get(c).equals(ss.get(i))) {
                    return false;
                }
            } 
            //如果不包含,进行映射
            else {
                map1.put(c,ss.get(i));
            }

            //将s作为key
            //如果在map2中包含c
            if(map2.containsKey(ss.get(i))) {
                //如果对应的字符串不是当前的字符串,直接返回false
                if(!map2.get(ss.get(i)).equals(c)) {
                    return false;
                }
            } 
            //如果不包含,进行映射
            else {
                map2.put(ss.get(i),c);
            }
        }
        return true;
    }
}

242. 有效的字母异位词

242. 有效的字母异位词

题目:

题解一:

java 复制代码
class Solution {
    public boolean isAnagram(String s, String t) {
        if(s.length()!=t.length()) {
            return false;
        }
        //分别用来统计s和t的字符串
        Map<Character,Integer> map1 = new HashMap<>();
        Map<Character,Integer> map2 = new HashMap<>();
        for(int i=0;i<s.length();i++) {
            Character ss = s.charAt(i);
            Character tt = t.charAt(i);
            map1.put(ss, map1.getOrDefault(ss, 0)+1);
            map2.put(tt, map2.getOrDefault(tt, 0)+1); 
        }
        if(map1.equals(map2)) {
            return true;
        }
        return false;
    }
}

题解二:

java 复制代码
class Solution {
    public boolean isAnagram(String s, String t) {
        if(s.length()!=t.length()) {
            return false;
        }
        char[] c1 = s.toCharArray();
        char[] c2 = t.toCharArray();
        //进行排序
        Arrays.sort(c1);
        Arrays.sort(c2);
        String s1 = new String(c1);
        String s2 = new String(c2);
        //转换成字符串,进行判断是否相等
        if(s1.equals(s2)) {
            return true;
        }
        return false;
    }
}

在写题解2的时候我一开始是想着直接让c1和c2比较,但是我发现报错,于是就换成转成字符串进行比较,然后完成该题之后就问了ai为什么不行,原因竟然是因为List的==比较还是equals来比较,都比较的是内存地址,就相当于都是==来比较。所以,如果我非要比较c1和c2,就必须用Arrays.equals(c1,c2)来比较。过程如下

java 复制代码
class Solution {
    public boolean isAnagram(String s, String t) {
        if(s.length()!=t.length()) {
            return false;
        }
        char[] c1 = s.toCharArray();
        char[] c2 = t.toCharArray();
        //进行排序
        Arrays.sort(c1);
        Arrays.sort(c2);
        // String s1 = new String(c1);
        // String s2 = new String(c2);
        //转换成字符串,进行判断是否相等
        // if(s1.equals(s2)) {
        //     return true;
        // }
        // return false;
        if(Arrays.equals(c1,c2)) {
            return true;
        }
        return false;
    }
}
相关推荐
韩小兔修媛史1 小时前
SpringCloud八股文面试
spring·spring cloud·面试
ShineWinsu1 小时前
对于Linux:线程局部存储(TLS)和线程封装的解析
linux·c++·面试·线程·tls·线程封装·线程局部存储
JAVA面经实录9172 小时前
高频算法面试题
java·计算机网络·算法·面试
JAVA9654 小时前
JAVA面试-JVM篇 02-G1垃圾收集器的工作原理是什么与CMS的区别
java·jvm·面试
古希腊掌管代码的神THU4 小时前
解析 MiniMax M3 多模态大模型的架构/源码?
人工智能·深度学习·自然语言处理·面试
CoderYanger4 小时前
Java EE:6.网络编程套接字(第二弹)
java·网络·程序人生·面试·职场和发展·java-ee·学习方法
橘子星4 小时前
树与二叉树:从概念到 JavaScript 实现
前端·javascript·面试
触底反弹4 小时前
面试官问"Ajax原理",我从XHR讲到async/await,他直接懵了!
前端·面试·架构
兰令水4 小时前
leecodecode【面试150】【2026.6.15打卡-java版本】
java·算法·面试
AI人工智能_电脑小能手4 小时前
【大白话说Java面试题 第106题】【并发篇】第6题:synchronized 锁的锁对象可以是什么?
java·后端·面试