关于后端:Python代码阅读第18篇变形词判断

12次阅读

共计 738 个字符,预计需要花费 2 分钟才能阅读完成。

Python 代码浏览合集介绍:为什么不举荐 Python 初学者间接看我的项目源码

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

本篇浏览的代码片段来自于 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())

# EXAMPLES
is_anagram("#anagram", "Nag a ram!")  # True

is_anagram函数输出两个字符串,查看一个字符串是否是另一个字符串的变形词(不辨别大小写,疏忽空格、标点符号和特殊字符)。函数顺次判断输出字符串中的字符是否是字母或数字,并通过 Counter 生成字母和数字的计数字典。通过比拟依据两个输出字符串创立的字典,判断他们是否互为变体。当技术字典雷同时,示意两个输出字符串蕴含雷同的字母或数字,并且他们的计数雷同,两个输出字符串互为变形词。

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

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

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

正文完
 0