[编辑:正如有人指出我不正确地使用了回文概念,现在我已经使用正确的函数进行了编辑。我还在第一个和第三个示例中做了一些优化,其中 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 语句在第一个不同的元素处中断,但我不认为这是一种优雅且Python式的方法
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
我认为第一个解决方案更优雅,第二个解决方案更高效