鱼C论坛

 找回密码
 立即注册
查看: 1004|回复: 3

[已解决]用python递归编写了一个程序但是答案一直是错误的求解~

[复制链接]
发表于 2018-1-9 22:45:51 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
编写了一个判断是不是回文字符串的程序如下
  1. def huiwen(x,one,last):
  2.     if one>last:
  3.         return 1
  4.     else:
  5.         if x[one]==x[last]:
  6.             huiwen(x,one+1,last-1)
  7.         else:
  8.             return 0

  9. x = input('请输入一个字符串')
  10. last = len(x)-1

  11. if huiwen(x,0,last):
  12.     print('是的')
  13. else:
  14.     print('不是')
复制代码

我输入'12321'这种回文字符串单显示结果一直不是
求解!!
最佳答案
2018-1-10 01:35:14
你这个递归,最后给的值是在后面的if里面,这样你的函数是没有返回值,为None的,既不是0,也不是1,所以只能结果只能是不是
  1. def huiwen(x,one,last):
  2.     if one>last:
  3.         return 1
  4.     else:
  5.         if x[one]==x[last]:
  6.             return huiwen(x,one+1,last-1)
  7.         else:
  8.             return 0

  9. x = input('请输入一个字符串')
  10. last = len(x)-1

  11. if huiwen(x,0,last):
  12.     print('是的')
  13. else:
  14.     print('不是')
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-1-10 01:35:14 | 显示全部楼层    本楼为最佳答案   
你这个递归,最后给的值是在后面的if里面,这样你的函数是没有返回值,为None的,既不是0,也不是1,所以只能结果只能是不是
  1. def huiwen(x,one,last):
  2.     if one>last:
  3.         return 1
  4.     else:
  5.         if x[one]==x[last]:
  6.             return huiwen(x,one+1,last-1)
  7.         else:
  8.             return 0

  9. x = input('请输入一个字符串')
  10. last = len(x)-1

  11. if huiwen(x,0,last):
  12.     print('是的')
  13. else:
  14.     print('不是')
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-1-10 09:08:21 | 显示全部楼层
因为递归很多次调用自身,只有最后一次才有返回值为1,当递归回归的时候都没有返回值,默认为None,你的if判断一直走else分支了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-1-10 10:14:18 | 显示全部楼层
我猜测你的思路是这样的:
输入一个字符串如果是一位,那么算是回文。如果是两位以上开始用递归算法比较第一位跟最后一位,如果一样就比较第二位跟倒数第二位,直到中间比对完毕。按照这个思路修改了下你的程序,你看下有没有帮助
def huiwen(x,one,last):
    i=0
    if one>last:
        i=1
    else:        
        if x[one]==x[last]:
            huiwen(x,one+1,last-1)
            i+=1
            if i==len(x)//2:
                i=1                     
        else:
            i=0
    return i
x = input('请输入一个字符串')
last = len(x)-1
if huiwen(x,0,last):
    print('是的')
else:
    print('不是')

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-6 00:14

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表