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;
    }
}
相关推荐
呼啦啦啦啦啦啦啦啦38 分钟前
常见的排序算法
java·算法·排序算法
胡萝卜3.02 小时前
数据结构初阶:排序算法(一)插入排序、选择排序
数据结构·笔记·学习·算法·排序算法·学习方法
地平线开发者2 小时前
LLM 中 token 简介与 bert 实操解读
算法·自动驾驶
lyx33136967592 小时前
Pandas数据结构详解Series与DataFrame
数据结构·pandas
scx201310042 小时前
20250814 最小生成树和重构树总结
c++·算法·最小生成树·重构树
阿巴~阿巴~3 小时前
冒泡排序算法
c语言·开发语言·算法·排序算法
散1123 小时前
01数据结构-交换排序
数据结构·算法
yzx9910133 小时前
Yolov模型的演变
人工智能·算法·yolo
weixin_307779134 小时前
VS Code配置MinGW64编译SQLite3库
开发语言·数据库·c++·vscode·算法
无聊的小坏坏4 小时前
拓扑排序详解:从力扣 207 题看有向图环检测
算法·leetcode·图论·拓扑学