力扣290. 单词规律

给定一种规律 pattern 和一个字符串 str ,判断 str 是否遵循相同的规律。

这里的 遵循 指完全匹配,例如, pattern 里的每个字母和字符串 str 中的每个非空单词之间存在着双向连接的对应规律。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/word-pattern

public boolean wordPattern(String pattern, String s) {

        HashMap <Character,String> mp = new HashMap<>();

        char[] pattern_chars=pattern.toCharArray();

        String[] ss = s.split(" ");  //按空格分割字符串

        if(pattern_chars.length!=ss.length)return false;//长度都不对应直接false

        int i=0;

        for(char a : pattern_chars){
            if(!mp.containsKey(a)){
                if(!mp.containsValue(ss[i])){  //对应value已存在但key值不同
                    mp.put(a,ss[i++]);
                }
                else return false;
            }
            else {//对应key值已存在但value不同,注意比较要用equals,用!=结果不对
                if(!Objects.equals(mp.get(a), ss[i++])) return false;
            }
        }
        return true;
    }

本题需要满足的是一种确定的映射关系,不可以出现一对多的映射,因此hashmap可以很好的验证这个问题,使用s.split(" "),使得对字符串的处理变得简单,然后遍历key值pattern,每次判断其value是否符合第一次存入时的value,当然,如果未存入则新存入。

要注意,string比较不可用==,原因懂得都懂,这是个坑,而字符比较必须用==,另外,注意i的管理,一次判断过后,需要使i的指针后移,也就是说,无论里面是否已经包含key,只要不return false ,都需要指针后移,忽略这个会导致很头痛。。。

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