Python 代码浏览合集介绍:为什么不举荐Python初学者间接看我的项目源码
本篇浏览的代码实现了判断两个字符串是否互为变形词的性能。
本篇浏览的代码片段来自于30-seconds-of-python。
is_anagram
from collections import Counterdef 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()
函数返回原字符串的正本,其所有辨别大小写的字符均转换为小写。