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;
    }
}
相关推荐
合方圆~小文1 天前
4G定焦球机摄像头综合介绍产品指南
数据结构·数据库·人工智能
老蒋新思维1 天前
反脆弱性设计:创始人IP与AI智能体如何构建愈动荡愈强大的知识商业|创客匠人
人工智能·网络协议·tcp/ip·算法·机器学习·创始人ip·创客匠人
Salt_07281 天前
DAY 36 官方文档的阅读
python·算法·机器学习·github
FMRbpm1 天前
串练习--------535.TinyURL的加密和解密
数据结构·c++·新手入门
明洞日记1 天前
【VTK手册027】VTK 颜色连续映射:vtkColorTransferFunction 深度解析与实战指南
c++·图像处理·算法·vtk·图形渲染
Bruce_kaizy1 天前
c++单调数据结构————单调栈,单调队列
开发语言·数据结构·c++
阿坤带你走近大数据1 天前
Python基础知识-数据结构篇
开发语言·数据结构·python
B_lack0261 天前
西门子PLC结构化编程_线性插值算法功能块
算法·pid·西门子plc·博途·线性插值·开环控制
fufu03111 天前
Linux环境下的C语言编程(四十三)
linux·c语言·算法
dragoooon341 天前
[C++——lesson32.数据结构进阶——「初识哈希」]
数据结构·c++·哈希算法