gpt4 book ai didi

python - 快速和 pythonic 的方法来找出一个字符串是否是回文

转载 作者:太空狗 更新时间:2023-10-30 00:49:01 24 4
gpt4 key购买 nike

[编辑:正如有人指出的那样,我不正确地使用了回文概念,现在我已经使用正确的函数进行了编辑。我在第一个和第三个示例中也做了一些优化,其中 for 语句一直运行到它到达字符串的一半]

我已经为检查字符串是否为回文的方法编写了三个不同的版本。该方法作为类“str”的扩展实现

这些方法还将字符串转换为小写,并删除所有的正点和空格。哪个更好(更快,pythonic)?

方法如下:

1)这是我想到的第一个解决方案:

    def palindrom(self):
lowerself = re.sub("[ ,.;:?!]", "", self.lower())
n = len(lowerself)
for i in range(n//2):
if lowerself[i] != lowerself[n-(i+1)]:
return False
return True

我认为这个更快,因为没有字符串的转换或反转,并且 for 语句在第一个不同的元素处中断,但我认为这不是一种优雅的 pythonic 方式

2) 在第二个版本中,我使用在 stackoverflow 上创建的解决方案进行了转换(使用高级切片字符串 [::-1])

# more compact
def pythonicPalindrom(self):
lowerself = re.sub("[ ,.;:?!]", "", self.lower())
lowerReversed = lowerself[::-1]
if lowerself == lowerReversed:
return True
else:
return False

但我认为字符串之间的切片和比较会使这个解决方案变慢。

3)我想到的第三个解决方案,使用迭代器:

# with iterator
def iteratorPalindrom(self):
lowerself = re.sub("[ ,.;:?!]", "", self.lower())
iteratorReverse = reversed(lowerself)
for char in lowerself[0:len(lowerself)//2]:
if next(iteratorReverse) != char:
return False
return True

我认为第一个解决方案更优雅,第二个解决方案更高效

最佳答案

所以,我决定只timeit,然后找出哪个最快。请注意,最终函数是您自己的 pythonicPalindrome 的更简洁版本。定义如下:

def palindrome(s, o):
return re.sub("[ ,.;:?!]", "", s.lower()) == re.sub("[ ,.;:?!]", "", o.lower())[::-1]

方法论

我为每个函数运行了 10 个不同的测试。在每次测试运行中,该函数被调用 10000 次,参数为 self="aabccccccbaa", other="aabccccccbaa"。结果可以在下面找到。

            palindrom       iteratorPalindrome      pythonicPalindrome      palindrome  
1 0.131656638 0.108762937 0.071676536 0.072031984
2 0.140950052 0.109713793 0.073781851 0.071860462
3 0.126966087 0.109586756 0.072349792 0.073776719
4 0.125113136 0.108729573 0.094633969 0.071474645
5 0.130878159 0.108602964 0.075770395 0.072455015
6 0.133569472 0.110276694 0.072811747 0.071764222
7 0.128642812 0.111065438 0.072170571 0.072285204
8 0.124896702 0.110218949 0.071898959 0.071841214
9 0.123841905 0.109278358 0.077430437 0.071747112
10 0.124083576 0.108184210 0.080211147 0.077391086

AVG 0.129059854 0.109441967 0.076273540 0.072662766
STDDEV 0.005387429 0.000901370 0.007030835 0.001781309

看起来您的 pythonicPalindrome 的更简洁版本稍微快一些,但是这两个功能明显优于其他选择。

关于python - 快速和 pythonic 的方法来找出一个字符串是否是回文,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34637002/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com