写点什么

Python 代码阅读(第 18 篇):变形词判断

用户头像
Felix
关注
发布于: 3 小时前
Python代码阅读(第18篇):变形词判断

本篇阅读的代码实现了判断两个字符串是否互为变形词的功能。


本篇阅读的代码片段来自于30-seconds-of-python

is_anagram

from collections import Counter
def is_anagram(s1, s2): return Counter( c.lower() for c in s1 if c.isalnum() ) == Counter( c.lower() for c in s2 if c.isalnum() )
# EXAMPLESis_anagram("#anagram", "Nag a ram!") # True
复制代码


is_anagram函数输入两个字符串,检查一个字符串是否是另一个字符串的变形词(不区分大小写,忽略空格、标点符号和特殊字符)。函数依次判断输入字符串中的字符是否是字母或数字,并通过Counter生成字母和数字的计数字典。通过比较根据两个输入字符串创建的字典,判断他们是否互为变体。当技术字典相同时,表示两个输入字符串包含相同的字母或数字,并且他们的计数相同,两个输入字符串互为变形词。


class collections.Counter([iterable-or-mapping])接收一个可迭代对象,并返回一个dict的子类,用于计数可哈希对象。它是一个集合,元素像字典键(key)一样存储,它们的计数存储为值。计数可以是任何整数值,包括 0 和负数。它可以接收一个可迭代对象,并对其元素进行计数。


str.isalnum()如果字符串中的所有字符都是字母或数字且至少有一个字符,则返回True, 否则返回False


str.lower()函数返回原字符串的副本,其所有区分大小写的字符均转换为小写。

发布于: 3 小时前阅读数: 4
用户头像

Felix

关注

还未添加个人签名 2018.05.04 加入

欢迎关注个人公众号:没看点 个人主页:www.zhangfelix.com

评论

发布
暂无评论
Python代码阅读(第18篇):变形词判断