迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > Python >

使用 Python 检查两个字符串是否为变位词

作者:迹忆客 最近更新:2023/03/01 浏览次数:

变位词是通过重新排列其他单词的字母而形成的单词。

例如,racecarelistensilentfriedfiredkneekeen 是一些变位词对。dadbadapplemangohelloworld 不是变位词。

使用编程语言,我们可以快速检查两个字符串是否互为变位词。

本文将展示如何使用 Python 检查两个字符串是否为变位词。我们将讨论一些相同的方法。

要检查两个字符串是否是变位词,我们可以对两个字符串进行排序并检查它们是否相等。相同的参考下面的代码。

由于排序,代码的时间复杂度为 O(nlogn),空间复杂度为 O(1),因为我们没有存储任何值。

def check_anagram(a, b):
    if a is None or b is None or len(a) != len(b):
        return "Not Anagram"
        
    return "Anagram" if sorted(a) == sorted(b) else "Not Anagram"

print(check_anagram("keen", "knee"))
print(check_anagram("race", "care"))
print(check_anagram("fried", "fired"))
print(check_anagram("apple", "paddle"))
print(check_anagram("first", "second"))
print(check_anagram(None, "second"))
print(check_anagram("first", None))
print(check_anagram(None, None))

输出:

Anagram
Anagram
Anagram
Not Anagram
Not Anagram
Not Anagram
Not Anagram
Not Anagram

要检查两个字符串是否是变位词,我们可以保留两个字符串中存在的字符数并比较计数。如果它们相同,这意味着这两个字符串是变位词。否则,他们不是。

相同的参考下面的代码。

以下解决方案的时间复杂度为 O(n),因为我们正在迭代两个字符串。将元素添加到字典并检索元素的平均时间复杂度为 O(1)

此外,比较具有相同键数的两个字典是 O(n)。而且,空间复杂度是 O(n),因为我们要维护两个字典,而在幕后,字典使用数组来存储键和值。

def check_anagram(a, b):
    if a is None or b is None or len(a) != len(b):
        return "Not Anagram"
        
    counts_a = {}
    counts_b = {}
    
    for x in a:
        if x not in counts_a.keys():
            counts_a[x] = 1
        else:
            counts_a[x] += 1
        
    for x in b:
        if x not in counts_b.keys():
            counts_b[x] = 1
        else:
            counts_b[x] += 1
        
    return "Anagram" if counts_a == counts_b else "Not Anagram"

print(check_anagram("keen", "knee"))
print(check_anagram("race", "care"))
print(check_anagram("fried", "fired"))
print(check_anagram("apple", "paddle"))
print(check_anagram("first", "second"))
print(check_anagram(None, "second"))
print(check_anagram("first", None))
print(check_anagram(None, None))

输出:

Anagram
Anagram
Anagram
Not Anagram
Not Anagram
Not Anagram
Not Anagram
Not Anagram

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

Pandas read_csv()函数

发布时间:2024/04/24 浏览次数:254 分类:Python

Pandas read_csv()函数将指定的逗号分隔值(csv)文件读取到 DataFrame 中。

Pandas 追加数据到 CSV 中

发布时间:2024/04/24 浏览次数:352 分类:Python

本教程演示了如何在追加模式下使用 to_csv()向现有的 CSV 文件添加数据。

Pandas 多列合并

发布时间:2024/04/24 浏览次数:628 分类:Python

本教程介绍了如何在 Pandas 中使用 DataFrame.merge()方法合并两个 DataFrames。

Pandas loc vs iloc

发布时间:2024/04/24 浏览次数:837 分类:Python

本教程介绍了如何使用 Python 中的 loc 和 iloc 从 Pandas DataFrame 中过滤数据。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便