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;
    }
}
相关推荐
Lee川10 小时前
优雅进化的JavaScript:从ES6+新特性看现代前端开发范式
javascript·面试
Lee川13 小时前
从异步迷雾到优雅流程:JavaScript异步编程与内存管理的现代化之旅
javascript·面试
晴殇i15 小时前
揭秘JavaScript中那些“不冒泡”的DOM事件
前端·javascript·面试
绝无仅有16 小时前
Redis过期删除与内存淘汰策略详解
后端·面试·架构
绝无仅有16 小时前
Redis大Key问题排查与解决方案全解析
后端·面试·架构
AAA梅狸猫17 小时前
Looper.loop() 循环机制
面试
AAA梅狸猫17 小时前
Handler基本概念
面试
Wect17 小时前
浏览器缓存机制
前端·面试·浏览器
掘金安东尼18 小时前
Fun with TypeScript Generics:玩转 TS 泛型
前端·javascript·面试
掘金安东尼18 小时前
Next.js 企业级落地
前端·javascript·面试