课后作业回文联
def judgehui(hui):length = len(hui)
a = len(hui)-1;b = 0;count = 0;x = len(hui)//2
if length % 2 ==0:
while x > 0:
if hui == hui:
count += 1
x -= 1
else:
while int(x) > 0:
if hui == hui:
count += 1
x -= 1
if count == int(x):
print('是回文联!')
else:
print('不是回文联!')
hui = input('请输入一句话:')
judgehui(hui)
我的代码永远不是回文联,请问哪里错了呢 本帖最后由 jackz007 于 2019-11-18 20:42 编辑
看不懂楼主的思路,于是就自己写了一遍,有一点可以肯定,每次比较字符串中的 2 个字符,所以,循环次数只需 length 的一半。
def judgehui(hui):
f, length = True , len(hui)
for i in range(length // 2) :
if hui != hui:
f = False
break
return f
if judgehui(input('请输入一句话:') . strip()) :
print('是回文联!')
else:
print('不是回文联!')
当然,这么写更简单:
hui = input('请输入一句话:') . strip()
if hui == hui[:: -1]:
print('是回文联!')
else:
print('不是回文联!') 代码写的太复杂,其实只要两三行代码就搞定:
def judgehui(s):
if s == s[::-1]:
print('是回文联!')
else:
print('不是回文联!')
hui = input('请输入一句话:')
judgehui(hui) jackz007 发表于 2019-11-18 20:30
看不懂楼主的思路,于是就自己写了一遍,有一点可以肯定,每次比较字符串中的 2 个字符,所以,循环 ...
hui[:: -1]是啥意思呢 本帖最后由 jackz007 于 2019-11-19 20:37 编辑
yooooly 发表于 2019-11-19 20:23
hui[:: -1]是啥意思呢
就是把可迭代对象逆序排列,对于字符串而言,就是把它首尾颠倒,例如,hui = 'ABCDEFG',那么,hui[:: -1] = 'GFEDCBA'。楼主自己也可以在 IDLE 环境中测试一下效果。
页:
[1]