Python 中的回文仅对字符串进行操作
Palindrome in Python operating on strings only
我正在尝试在 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()))
这里你得到一个打印回文的单行代码:
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','EVE','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
要检测回文,只需检查反向字符串是否等于原始字符串
palindromes_test = ['ABCDCBA','EVE','ABCABC']
print ([v for v in palindromes_test if (v == (v[::-1]))])
输出
['ABCDCBA', 'EVE']
我正在尝试在 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()))
这里你得到一个打印回文的单行代码:
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','EVE','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
要检测回文,只需检查反向字符串是否等于原始字符串
palindromes_test = ['ABCDCBA','EVE','ABCABC']
print ([v for v in palindromes_test if (v == (v[::-1]))])
输出
['ABCDCBA', 'EVE']