鱼C论坛

 找回密码
 立即注册
查看: 1320|回复: 1

[已解决]递归函数

[复制链接]
发表于 2020-3-3 11:24:15 | 显示全部楼层 |阅读模式

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

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

x
递归好难啊,老师的课好不容易听懂了,结果作业几乎都不会
写作业就感觉到还是不太懂,哪位大神能帮帮忙,解读一下下面的代码,如果能提供一些建议就更感激了第23,24讲课后习题第二题:


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)



最佳答案
2020-3-3 12:48:29
一个字符串如果正着读与倒着读的意思一样,就可以称为"回文字符串"。如:abccba,abcba

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
#这里是比对字符串
#第一次:比对字符串第一个和最后一个的元素,如果相等就继续递归,不相等就结束返回0,即不是回文字符串
#第二次则是比对字符串里第二个和倒数第二个元素,道理相同
#递归直到start>end时结束,这是字符串里所有的元素都已经比对过了且比对的结果都是相等,所以返回1,即字符串是回文字符串

string = input('请输入一串字符串:')
length = len(string)-1
#len(string)-1是为了获得string最后一个字的索引,方面后面比对字符串的元素

if is_palindrome(string, 0, length):
        print('"%s"是回文字符串!' % string)
else:
        print('"%s"不是回文字符串!' % string
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-3-3 12:48:29 From FishC Mobile | 显示全部楼层    本楼为最佳答案   
一个字符串如果正着读与倒着读的意思一样,就可以称为"回文字符串"。如:abccba,abcba

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
#这里是比对字符串
#第一次:比对字符串第一个和最后一个的元素,如果相等就继续递归,不相等就结束返回0,即不是回文字符串
#第二次则是比对字符串里第二个和倒数第二个元素,道理相同
#递归直到start>end时结束,这是字符串里所有的元素都已经比对过了且比对的结果都是相等,所以返回1,即字符串是回文字符串

string = input('请输入一串字符串:')
length = len(string)-1
#len(string)-1是为了获得string最后一个字的索引,方面后面比对字符串的元素

if is_palindrome(string, 0, length):
        print('"%s"是回文字符串!' % string)
else:
        print('"%s"不是回文字符串!' % string
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-21 22:19

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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