我正在尝试编写一个程序来检查输入的字符串是否是回文,使用堆栈的基本概念。我很困惑在stack1.insert函数中输入什么索引。请帮忙?或者你认为有一个更简单的方法吗?
def palindrome(str1):
stack1 = []
palInd = False
for chr in str1:
stack1.insert(0, chr)
for i in range(len(str1)-1):
if str1[i]==stack1.pop():
palInd = True
else:
palInd = False
return palInd
print palindrome("madam")
答案 0 :(得分:0)
import collections
def is_palindrome(string):
palindrome = collections.deque(string)
while len(palindrome) > 1:
if palindrome.popleft() != palindrome.pop():
return False
return True
答案 1 :(得分:0)
虽然堆栈可以解决这个问题,但我认为我有一个简单的迭代方法:
def palindrome(string):
chars = list(string)
for i in range(0,len(chars)/2):
if (chars[i] != chars[len(chars)-i-1]):
return False
return True
这是一个测试:
print palindrome("sees")
print palindrome("racecar")
print palindrome("not a palindrome")
print palindrome("madam")
结果是:
True
True
False
True
答案 2 :(得分:0)
好吧,如果你正在寻找更简单的方法......最简单的方法就是使用切片:
def is_pal(a):
return a == a[::-1]
这有很多变化,主要涉及从两端进行迭代。
def is_pal(a):
return a == ''.join(reversed(a))
def is_pal(a):
forwards,backwards = iter(a), reversed(a)
return all(x==y for x,y in zip(forwards,backwards))
从技术上讲,如果你是最优的(可能处理一些GIANT回文)你不需要遍历整个字符串,只需在中间相遇:
def is_pal(a):
halflen = len(a) // 2
forwards,backwards = iter(a[:halflen]), reversed(a[halflen:])
return all(x==y for x,y in zip(forwards,backwards))
这最终接近你正在做的两端的双端队列。