leetcode_290. 单词规律

举报
悲恋花丶无心之人 发表于 2021/02/03 01:18:52 2021/02/03
【摘要】 目录 一、题目内容 二、解题思路 三、代码 一、题目内容 给定一种规律 pattern 和一个字符串 str ,判断 str 是否遵循相同的规律。 这里的 遵循 指完全匹配,例如, pattern 里的每个字母和字符串 str 中的每个非空单词之间存在着双向连接的对...

目录

一、题目内容

二、解题思路

三、代码


一、题目内容

给定一种规律 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

说明:
你可以假设 pattern 只包含小写字母, str 包含了由单个空格分隔的小写字母。    

二、解题思路

两个dict构成双向关系,pattern和s里的元素可互相作为键值对进行查找,如果有一个dict通过key查找的value值和当前值不对应则返回False,否则查找结束返回True。

三、代码


  
  1. class Solution:
  2. def wordPattern(self, pattern: str, s: str) -> bool:
  3. s_split_list = s.split(' ')
  4. pattern_list = list(pattern)
  5. if len(s_split_list) != len(pattern_list):
  6. return False
  7. s_pattern_dict = {}
  8. pattern_s_dict = {}
  9. for i, j in zip(s_split_list, pattern_list):
  10. if i not in s_pattern_dict:
  11. s_pattern_dict[i] = j
  12. if j not in pattern_s_dict:
  13. pattern_s_dict[j] = i
  14. if s_pattern_dict[i] != j:
  15. return False
  16. if pattern_s_dict[j] != i:
  17. return False
  18. return True
  19. if __name__ == '__main__':
  20. pattern = "aba"
  21. strs = "dog dog dog dog"
  22. s = Solution()
  23. ans = s.wordPattern(pattern, strs)
  24. print(ans)

文章来源: nickhuang1996.blog.csdn.net,作者:悲恋花丶无心之人,版权归原作者所有,如需转载,请联系作者。

原文链接:nickhuang1996.blog.csdn.net/article/details/111246406

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。