LeetCode每日一题 单词规律(哈希表)

题目描述

  1. 给定一种规律 pattern 和一个字符串 s ,判断 s 是否遵循相同的规律。
  2. 这里的 遵循 指完全匹配,例如, pattern 里的每个字母和字符串 s中的每个非空单词之间存在着双向连接的对应规律。

示例 1:

复制代码
输入: pattern = "abba", s = "dog cat cat dog"

输出: true

示例 2:

复制代码
输入:pattern = "abba", s = "dog cat cat fish"

输出: false

示例 3:

复制代码
输入: pattern = "aaaa", s = "dog cat cat dog"

输出: false

提示:

  • 1 <= pattern.length <= 300
  • pattern 只包含小写英文字母
  • 1 <= s.length <= 3000
  • s 只包含小写英文字母和 ' '
  • s 不包含 任何前导或尾随对空格
  • s 中每个单词都被 单个空格分隔

解题思路:

创建两个哈希表,表中记录字符的对应关系,如果字符的对应关系已经出现过了或不等于之间记录的对应关系,则返回false

题解:

java 复制代码
class Solution {
    public boolean wordPattern(String pattern, String s) {
        String[]words=s.split(" ");
        
        Map<String,Character>str2char=new HashMap<>();
        Map<Character,String>char2str=new HashMap<>();

        int n=words.length,m=pattern.length();
        if(n!=m) return false;
        for (int i = 0; i <n ; i++) {
            Character c=pattern.charAt(i);
            String str=words[i];
            //一种为false的情况是:多个c对应于一个str
            if(char2str.get(c)!=null&&!char2str.get(c).equals(str)){
                return false;
            }
            //另一种为false的情况是:多个str对应于一个c
            if(str2char.get(str)!=null&&!str2char.get(str).equals(c)){
                return false;
            }
            str2char.put(str,c);
            char2str.put(c,str);
        }
        return true;
    }
}
相关推荐
bbq粉刷匠5 分钟前
Java-排序2
java·数据结构·排序算法
皮皮哎哟5 分钟前
冒泡排序与数组传递全解析 一维二维指针数组及二级指针应用指南
c语言·算法·冒泡排序·二维数组·指针数组·传参·二级指针
m0_561359676 分钟前
C++代码冗余消除
开发语言·c++·算法
近津薪荼17 分钟前
优选算法——滑动窗口1(单调性)
c++·学习·算法
diediedei18 分钟前
嵌入式C++驱动开发
开发语言·c++·算法
燃于AC之乐23 分钟前
《算法实战笔记》第10期:六大算法实战——枚举、贪心、并查集、Kruskal、双指针、区间DP
算法·贪心算法·图论·双指针·区间dp·二进制枚举
diediedei28 分钟前
高性能计算通信库
开发语言·c++·算法
蒸蒸yyyyzwd28 分钟前
算法学习笔记
笔记·算法
TracyCoder12336 分钟前
Redis 进阶之路:探秘事务、Lua 与特殊数据结构
数据结构·redis·lua
练习时长一年37 分钟前
LeetCode热题100(颜色分类)
算法·leetcode·职场和发展