290. 单词规律

290. 单词规律

  • 题目-简单难度
  • 示例
  • 1.
  • 2. 参考‘205. 同构字符串’

题目-简单难度

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

这里的 遵循 指完全匹配,例如, 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 中每个单词都被 单个空格 分隔

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/word-pattern
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

1.

执行用时:20 ms, 在所有 Python 提交中击败了40.08%的用户
内存消耗:13 MB, 在所有 Python 提交中击败了75.53%的用户
通过测试用例:41 / 41

class Solution(object):
    def wordPattern(self, pattern, s):
        """
        :type pattern: str
        :type s: str
        :rtype: bool
        """
        # 把单词放到list内
        sli = s.split(" ")
        # 如果单词数量和pattern数量匹配不上,返回False
        if len(sli) != len(pattern):
            return False
        # 如果达到以下条件,证明能够完全映射
        return len(set(pattern)) == len(set(sli)) == len(set(zip(pattern,sli)))

2. 参考‘205. 同构字符串’

205. 同构字符串(简单)

执行用时:20 ms, 在所有 Python 提交中击败了40.08%的用户
内存消耗:13.1 MB, 在所有 Python 提交中击败了40.51%的用户
通过测试用例:41 / 41

class Solution(object):
    def wordPattern(self, pattern, s):
        """
        :type pattern: str
        :type s: str
        :rtype: bool
        """
        sli = s.split(" ")
        if len(sli) != len(pattern):
            return False
        dics = defaultdict(list)
        dicp = defaultdict(list)
        for i,e in enumerate(pattern):
            dicp[e].append(i)
        for i,e in enumerate(sli):
            dics[e].append(i)
        return sorted(list(dics.values())) == sorted(list(dicp.values()))

你可能感兴趣的:(哈希表,算法,python,算法,leetcode)