如何解决Python 中的回文仅对字符串进行操作
我正在尝试用 Python 编写一个程序,该程序将检测用户给出的单词是否为回文。
这是我的代码 - 我只对字符串进行操作 - 我的解决方案与我在这里或任何地方看到的其他解决方案完全不同,因此我希望你 - StactOverFlow 用户 ;) - 检查其正确性。
我不必说我不是专业人士,拥有相当基础的知识。 但是,如果有人花时间给我一些反馈,我会很高兴。
# a palindrome
string = input('word: ')
if(len(string) % 2 != 0):
left = string.lower()[0:int((len(string)-1)/2)]
right = string.lower()[int((len(string)-1)/2 + 1): ]
if left == right[::-1]:
print('{} is a palindrome'.format(string.lower()))
else:
print('{} is not a palindrome'.format(string))
else:
left = string.lower()[0:int((len(string)/2))]
right = string.lower()[int(len(string)/2):]
if left == right[::-1]:
print('{} is a palindrome'.format(string.lower()))
else:
print('{} is not a palindrome'.format(string.lower()))
解决方法
检测回文只需检查反向字符串是否等于原始字符串
palindromes_test = ['ABCDCBA','EVE','ABCABC']
print ([v for v in palindromes_test if (v == (v[::-1]))])
输出
['ABCDCBA','EVE']
,
这里你得到一个打印回文的oneliner:
print ([v for v in palindromes_test if (len(v) % 2 == 0 and v[0:len(v)//2] == v[len(v)//2:][::-1]) or (len(v) % 2 != 0 and v[0:len(v)//2] == v[len(v)//2+1:][::-1])])
否则:
palindromes_test = ['ABCDCBA','ABCABC']
for elem in palindromes_test:
if len(elem) % 2 == 0 and elem[0:len(elem)//2] == elem[len(elem)//2:][::-1]:
print ("%s palindrome" % elem)
elif len(elem) % 2 != 0 and elem[0:len(elem)//2] == elem[len(elem)//2+1:][::-1]:
print ("%s palindrome" % elem)
else:
print ("%s not palindrome" % elem)
输出:
ABCDCBA palindrome
EVE palindrome
ABCABC not palindrome
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。