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;
    }
}
相关推荐
chipsense13 分钟前
霍尔电流传感器选型方法论再升级:从800V平台到TMR竞争的全场景决策树
算法·决策树·机器学习·闭环霍尔·tmr传感
CoderYanger28 分钟前
14届蓝桥杯省赛Java A 组Q1~Q3
java·开发语言·线性代数·算法·职场和发展·蓝桥杯
想唱rap37 分钟前
C++智能指针
linux·jvm·数据结构·c++·mysql·ubuntu·bash
会编程的土豆2 小时前
【日常做题】 代码随想录(岛屿最大面积+寻宝)
数据结构·算法·图论
阿洛学长2 小时前
汉洛塔结构思维
算法
木子n12 小时前
第2篇:坐标变换与数学基础:FOC算法的核心数学工具
算法·电机控制·foc
阿Y加油吧2 小时前
两道经典 DP 题:零钱兑换 & 单词拆分(完全背包 + 字符串 DP)
算法
疯狂打码的少年2 小时前
有序线性表删除一个元素:顺序存储 vs 单链表,平均要移动多少个元素?
数据结构·算法·链表
y = xⁿ2 小时前
20天速通LeetCode day07:前缀和
数据结构·算法·leetcode
载数而行5203 小时前
算法集训1:模拟,枚举,错误分析,前缀和,差分
算法