鱼C论坛

 找回密码
 立即注册
查看: 514|回复: 8

[已解决]回文 用递归法 求助

[复制链接]
发表于 2020-5-22 16:31:05 | 显示全部楼层 |阅读模式

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

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

x
def is_palindrome(n, start, end):
        if start > end:
                return 1     
        else:
                return is_palindrome(n, start+1, end-1) if n[start] == n[end] else 0
        
string = input('请输入一串字符串:')
length = len(string)-1

if is_palindrome(string, 0, length):
        print('"%s"是回文字符串!' % string)
else:
        print('"%s"不是回文字符串!' % string)



大佬们,求助啊!
1. 为什么在定义方法的时候, 要return1 或者0 呢? 他们是代表true or false 吗??

2.  if start > end:
    return 1
为什么这个地方前边字母的index 大于后边字母 的 index 就要return1 呢?


两个问题 求大佬点播。。 学到递归之后好挫败啊
最佳答案
2020-5-22 16:41:32
第一个问题你的理解是对的,

第二个问题 start 开始位置参数 都比 end 末尾的位置参数大了,说明前面递归过程中 if n[start] == n[end] 都是成立的  说明就是回文啦
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-5-22 16:32:47 | 显示全部楼层
点播  嘿嘿
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-22 16:41:32 | 显示全部楼层    本楼为最佳答案   
第一个问题你的理解是对的,

第二个问题 start 开始位置参数 都比 end 末尾的位置参数大了,说明前面递归过程中 if n[start] == n[end] 都是成立的  说明就是回文啦
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-22 16:45:08 | 显示全部楼层
哈 谢谢 理解啦,  这个头像好可爱
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-22 16:45:50 | 显示全部楼层
hwang.me 发表于 2020-5-22 16:45
哈 谢谢 理解啦,  这个头像好可爱

哈哈  是滴 ,我还在编辑你 你真的全理解了嘛
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-22 16:46:41 | 显示全部楼层
这个我理解啦 昨天那个 二进制的 return 那里  我还是不能理解。。 我给你回复啦。。。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-22 16:47:19 | 显示全部楼层
Twilight6 发表于 2020-5-22 16:41
第一个问题你的理解是对的,

第二个问题 start 开始位置参数 都比 end 末尾的位置参数大了,说明前面递 ...

1. 为什么在定义方法的时候, 要return1 或者0 呢? 他们是代表true or false 吗??

是的,0代表False,非零数都代表 True


2.  if start > end:
    return 1
为什么这个地方前边字母的index 大于后边字母 的 index 就要return1 呢?

这个地方用于递归最后一次呀,递归到最后说明前面的所有  if n[start] == n[end] 都是成立的 说明是回文联 return 1 代表 返回 True 嘛用于后面代码
if is_palindrome(string, 0, length):
        print('"%s"是回文字符串!' % string)
else:
        print('"%s"不是回文字符串!' % string)
判断是不是回文,如果返回 1 就执行 if 条件语句 否则执行else
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-5-22 16:52:43 | 显示全部楼层
hwang.me 发表于 2020-5-22 16:46
这个我理解啦 昨天那个 二进制的 return 那里  我还是不能理解。。 我给你回复啦。。。。

我也给你回复了,如果帮助到你 记得最佳 嘿嘿 ~   
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-5-22 16:55:58 | 显示全部楼层
Twilight6 发表于 2020-5-22 08:52
我也给你回复了,如果帮助到你 记得最佳 嘿嘿 ~

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-21 04:45

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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