算法千题案例⚡️每日LeetCode打卡⚡️——65.单词规律

Posted 呆呆敲代码的小Y

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了算法千题案例⚡️每日LeetCode打卡⚡️——65.单词规律相关的知识,希望对你有一定的参考价值。


📢前言

🚀 算法题 🚀
  • 🌲 每天打卡一道算法题,既是一个学习过程,又是一个分享的过程😜
  • 🌲 提示:本专栏解题 编程语言一律使用 C# 和 Java 两种进行解题
  • 🌲 要保持一个每天都在学习的状态,让我们一起努力成为算法大神吧🧐!
  • 🌲 今天是力扣算法题持续打卡第65天🎈!
🚀 算法题 🚀

🌲原题样例:二叉树的所有路径

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

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

示例1:

输入: pattern = "abba", str = "dog cat cat dog"
输出: true

示例2:

输入:pattern = "abba", str = "dog cat cat fish"
输出: false

示例 3:

输入: pattern = "aaaa", str = "dog cat cat dog"
输出: false

示例 4:

输入: pattern = "abba", str = "dog dog dog dog"
输出: false

🌻C#方法:递归

将patter的每个字母和S的每个单词分别存在俩个字典内互相对应,每次枚举的时候都比较是否相等,
如果不相等就返回false,全部通过就返回true

代码:

public class Solution
{
    public bool WordPattern(string pattern, string s)
    {
        Dictionary<char, string> dic = new Dictionary<char, string>();
        Dictionary<string, char> dic1 = new Dictionary<string, char>();
        var newS = s.Split(' ');//分割的S单词
        if(pattern.Length != newS.Length) return false;//检测长度,长度不等直接返回false

        for(int i = 0; i < pattern.Length; i++)
        {
            if(dic.ContainsKey(pattern[i]) || dic1.ContainsKey(newS[i]))//只要有一个字典含有键就进入判断
            {
                if (!dic.ContainsKey(pattern[i])) return false;
                if (!dic1.ContainsKey(newS[i])) return false;//如果有一个字典有Key另一个没有Key,一定不能通过
                if(dic[pattern[i]] != newS[i] || dic1[newS[i]] != pattern[i])//俩个都有Key,开始比较Value是否相等
                {
                    return false;
                }
            }
            else
            {
                if (!dic.ContainsKey(pattern[i]))//建立映射
                {
                    dic.Add(pattern[i], newS[i]);
                }
                if (!dic1.ContainsKey(newS[i]))//建立映射
                {
                    dic1.Add(newS[i], pattern[i]);
                }
            }
        }
        return true;
    }
}

执行结果

通过
执行用时:88 ms,在所有 Java  提交中击败了22.50%的用户
内存消耗:36.4 MB,在所有 Java 提交中击败了12.50%的用户

🌻Java 方法:哈希表

思路解析

  • 在本题中,我们需要判断字符与字符串之间是否恰好一一对应。即任意一个字符都对应着唯一的字符串,任意一个字符串也只被唯一的一个字符对应。在集合论中,这种关系被称为「双射」。

  • 想要解决本题,我们可以利用哈希表记录每一个字符对应的字符串,以及每一个字符串对应的字符。然后我们枚举每一对字符与字符串的配对过程,不断更新哈希表,如果发生了冲突,则说明给定的输入不满足双射关系。

  • 在实际代码中,我们枚举pattern 中的每一个字符,利用双指针来均摊线性地找到该字符在str 中对应的字符串。每次确定一个字符与字符串的组合,我们就检查是否出现冲突,最后我们再检查两字符串是否比较完毕即可。

代码:

class Solution {
    public boolean wordPattern(String pattern, String str) {
        Map<String, Character> str2ch = new HashMap<String, Character>();
        Map<Character, String> ch2str = new HashMap<Character, String>();
        int m = str.length();
        int i = 0;
        for (int p = 0; p < pattern.length(); ++p) {
            char ch = pattern.charAt(p);
            if (i >= m) {
                return false;
            }
            int j = i;
            while (j < m && str.charAt(j) != ' ') {
                j++;
            }
            String tmp = str.substring(i, j);
            if (str2ch.containsKey(tmp) && str2ch.get(tmp) != ch) {
                return false;
            }
            if (ch2str.containsKey(ch) && !tmp.equals(ch2str.get(ch))) {
                return false;
            }
            str2ch.put(tmp, ch);
            ch2str.put(ch, tmp);
            i = j + 1;
        }
        return i >= m;
    }
}

执行结果

通过
执行用时:1 ms,在所有 Java  提交中击败了90.26%的用户
内存消耗:36.3 MB,在所有 Java 提交中击败了51.35%的用户

复杂度分析

时间复杂度:O( n+m )
空间复杂度:O( n+m ) ,其中 Σ 是字符串的字符集。哈希表存储字符的空间取决于字符串的字符集大小,最坏情况下每个字符均不相同,需要O(∣Σ∣) 的空间。



💬总结

  • 今天是力扣算法题打卡的第六十五天!
  • 文章采用 C#Java 两种编程语言进行解题
  • 一些方法也是参考力扣大神写的,也是边学习边分享,再次感谢算法大佬们
  • 那今天的算法题分享到此结束啦,明天再见!

以上是关于算法千题案例⚡️每日LeetCode打卡⚡️——65.单词规律的主要内容,如果未能解决你的问题,请参考以下文章

算法千题案例⚡️每日LeetCode打卡⚡️——65.单词规律

算法千题案例⚡️每日LeetCode打卡⚡️——50.丢失的数字

算法千题案例⚡️每日LeetCode打卡⚡️——58.岛屿的周长

算法千题案例⚡️每日LeetCode打卡⚡️——60.提莫攻击

算法千题案例⚡️每日LeetCode打卡⚡️——52.两个数组的交集

算法千题案例⚡️每日LeetCode打卡⚡️——54.第三大的数