鱼C论坛

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

[已解决]课后习题的疑问

[复制链接]
发表于 2018-4-14 20:16:19 | 显示全部楼层 |阅读模式

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

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

x
还记得求回问字符串那道题吗?现在让你使用递归的方式来求解。

解题思路:有好多种方法,不过综合效率来说,下面的方法比较朴素:
利用递归每次索引前后2个字符进行对比,当start > end的时候,也正是首尾下标“碰面”的时候
即作为结束递归的条件。

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)


问题:麻烦大神给个注释。
另外,第二部分的length语句和上部分是什么样的联系?
最佳答案
2018-4-14 21:39:58
  1. #!/usr/bin/env python
  2. #-*-coding:utf-8-*-
  3. def is_palindrome(n, start, end):
  4.     if start > end:
  5.         return 1     
  6.     else:
  7.         return is_palindrome(n, start+1, end-1) if n[start] == n[end] else 0

  8. string = input('请输入一串字符串:')
  9. length = len(string)-1#这里也可以写成end = len(string)-1就是最后一个字符的下标

  10. if is_palindrome(string, 0, length):#这个递归函数中的第一个参数是string就是你输入的字符串,第二个参数0就是第一个字符的下标
  11.     #最后一个参数length就是最后一个字符的下标,然后递归函数进行判断,要是回文的话就返回1,要不是就是返回0
  12.     #对应的if语句,值是1执行if,值是0,执行else
  13.     print('"%s"是回文字符串!' % string)
  14. else:
  15.     print('"%s"不是回文字符串!' % string)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2018-4-14 21:39:58 | 显示全部楼层    本楼为最佳答案   
  1. #!/usr/bin/env python
  2. #-*-coding:utf-8-*-
  3. def is_palindrome(n, start, end):
  4.     if start > end:
  5.         return 1     
  6.     else:
  7.         return is_palindrome(n, start+1, end-1) if n[start] == n[end] else 0

  8. string = input('请输入一串字符串:')
  9. length = len(string)-1#这里也可以写成end = len(string)-1就是最后一个字符的下标

  10. if is_palindrome(string, 0, length):#这个递归函数中的第一个参数是string就是你输入的字符串,第二个参数0就是第一个字符的下标
  11.     #最后一个参数length就是最后一个字符的下标,然后递归函数进行判断,要是回文的话就返回1,要不是就是返回0
  12.     #对应的if语句,值是1执行if,值是0,执行else
  13.     print('"%s"是回文字符串!' % string)
  14. else:
  15.     print('"%s"不是回文字符串!' % string)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-4-14 21:42:25 | 显示全部楼层
递归函数就是第一个字符和最后一个字符进行比较,若相等就是进行下一层递归就是第二个字符和倒数第二个字符进行比较,,,,一直进行到终止条件就是首尾碰头的时候,若在这个过程中都是相等的话就输出1,要不就是在某一个过程中输出0
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-3-10 15:04

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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