LeetCode150道面试经典题--单词规律(简单)

1.题目

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

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

2.示例

pattern="abba"

s = "cat dog dog cat"

返回 true
pattern="abba"

s = "cat pig dog cat"

返回 false
pattern="ab"

s = "cat cat"

返回 false
提示

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

3.思路

哈希表:

首先看到映射相关问题就得联想到哈希表,然后先分析特殊情况,比如s为空或者s里面的字母个数和pattern的个数不匹配则直接返回false,否则正常情况下,先将s通过spilt方法进行切割后,在遍历s情况下,不存在的键值对应的映射就存入哈希表中,存在的就比较是否相等即可。

如果不了解哈希表则可以通过以下内容了解相关知识

Java类集框架(二)_Alphamilk的博客-CSDN博客

4.代码

LeetCode代码:

使用时间优先代码:

java 复制代码
class Solution {
    public boolean wordPattern(String pattern, String s) {
//        判断两种特殊情况
        if (s.length() ==0){
            return false;
        }
        String ss[] = s.split(" ");
        if (ss.length != pattern.length()){
            return false;
        }

//        正常情况
        HashMap<Character,String> map = new HashMap<>();
        for (int i= 0;i<pattern.length();i++){
            if (!map.containsKey(pattern.charAt(i))){
                if (map.containsValue(ss[i])){
                    return false;
                }
                map.put(pattern.charAt(i),ss[i]);
            }else {
                if (!map.get(pattern.charAt(i)).equals(ss[i])){
                    return false;
                }
            }
        }
        return true;
    }
}

还有一种做法是通过构造两个哈希表实现,内存上稍微会优于该算法,但是时间上会慢一些。

案例详细代码:

java 复制代码
package LeetCode14;

import java.util.Arrays;
import java.util.HashMap;

public class javaDemo {
    public static void main(String[] args) {
        String pattern = "abbc";
        String s = "";
        boolean flag = true;

//        判断两种特殊情况
//        当s为空
        if (s.length() ==0){
            flag = false;
        }
//        当ss中单词个数与pattern个数不匹配情况
        String ss[] = s.split(" ");
        if (ss.length != pattern.length()){
            flag = false;
        }

//        正常情况
        HashMap<Character,String> map = new HashMap<>();
//        遍历整个pattern
        for (int i= 0;i<pattern.length();i++){
//            判断是否存在键值
            if (!map.containsKey(pattern.charAt(i))){
//                判断值是否已经对应其他键值
                if (map.containsValue(ss[i])){
                    flag = false;
                    break;
                }
//              不满足前面条件的话就正常放入
                map.put(pattern.charAt(i),ss[i]);
            }else {
//                如果有存在的键,则进行比较
                if (!map.get(pattern.charAt(i)).equals(ss[i])){
                    flag = false;
                    break;
                }
            }
        }
//        输出flag
        System.out.println(flag);
    }
}

会了?试试挑战下一题!♪(^∀^●)ノシ (●´∀`)♪

LeetCode150道面试经典题-- 有效的字母异位词(简单)_Alphamilk的博客-CSDN博客

相关推荐
唐青枫1 小时前
Java 虚拟线程实战指南:从 Thread API 到 Spring Boot 高并发应用
java
kyriewen11 小时前
面试官问你:“AI 能写 80% 的代码了,公司为什么还需要你?”
前端·javascript·面试
冬奇Lab12 小时前
每日一个开源项目(第141篇):hiring-agent - HackerRank 开源了他们的简历评分系统,你的简历能得几分?
人工智能·面试·开源
kyriewen16 小时前
今天的科技圈,全在抢英伟达的饭碗
前端·面试·ai编程
白鲸开源17 小时前
Apache SeaTunnel Zeta Engine 的 Basic Auth 是怎么工作的?
java·vue.js·github
白鲸开源17 小时前
一文读懂DolphinScheduler插件机制:如何轻松扩展任务类型与数据源
java·架构·github
北域码匠20 小时前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
张元清21 小时前
React useIsomorphicLayoutEffect:修掉 SSR 下的 useLayoutEffect 警告(2026)
前端·javascript·面试
PBitW21 小时前
直接让GPT每日训练我!!!😕😕😕
前端·javascript·面试
用户2986985301421 小时前
Java 实现 Word 文档文本查找与高亮标注
java·后端