鱼C论坛

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

[已解决]递归实现

[复制链接]
发表于 2022-9-28 17:37:28 | 显示全部楼层 |阅读模式

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

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

x
请大神帮忙看看 谢谢啦
最佳答案
2022-9-28 18:38:30
本帖最后由 zhangjinxuan 于 2022-9-28 19:38 编辑

代码注释详细讲解,写这个不容易,求设最佳

  1. def open_boxs(n):
  2.     if n == 0: #判断边界条件,如果n等于0,那么就可以取出钻戒了
  3.         print("取出钻戒")
  4.         return #必须返回,否则会死递归
  5.     print("打开第", n, "层盒子") #先打开第n层盒子
  6.     open_boxs(n - 1) #再打开第n - 1层盒子

  7. def close_boxs(n):
  8.     #注:在这里,是先递归,在盖上,因为要盖上第n层盒子需要盖上n - 1层盒子
  9.     if n == 0: #判断边界条件,如果要盖上第0层盒子,说明盒子就盖完了,返回
  10.         return
  11.     close_boxs(n - 1) #盖上第n - 1层盒子
  12.     print("盖上第", n, "层盒子") #输出

  13. def main():
  14.     n = int(input("输入包装的层数: ")) #先输入
  15.     open_boxs(n) #再打开
  16.     close_boxs(n) #接着盖上
  17.     print("还原包装") #然后还原
  18.     return 0 #最后返回

  19. main()
复制代码
7F4EA17052818AD29369D3BF1625110A.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-9-28 17:51:09 | 显示全部楼层
看什么?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-9-28 17:58:41 | 显示全部楼层
本帖最后由 jackz007 于 2022-9-28 18:53 编辑
  1. def foo(n):
  2.     if not n:
  3.         print('取出钻戒')
  4.     else:
  5.         print('打开第' , n , '层盒子')
  6.         foo(n - 1)
  7.         print('盖上第' , n , '层盒子')        
  8.    
  9. n = int(input('输入包装层数:'))
  10. foo(n)
  11. print('还原包装')
复制代码

        运行实况:
  1. D:\[00.Exerciese.2022]\Python>python x.py
  2. 输入包装层数:8
  3. 打开第 8 层盒子
  4. 打开第 7 层盒子
  5. 打开第 6 层盒子
  6. 打开第 5 层盒子
  7. 打开第 4 层盒子
  8. 打开第 3 层盒子
  9. 打开第 2 层盒子
  10. 打开第 1 层盒子
  11. 取出钻戒
  12. 盖上第 1 层盒子
  13. 盖上第 2 层盒子
  14. 盖上第 3 层盒子
  15. 盖上第 4 层盒子
  16. 盖上第 5 层盒子
  17. 盖上第 6 层盒子
  18. 盖上第 7 层盒子
  19. 盖上第 8 层盒子
  20. 还原包装

  21. D:\[00.Exerciese.2022]\Python>
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-9-28 18:38:30 | 显示全部楼层    本楼为最佳答案   
本帖最后由 zhangjinxuan 于 2022-9-28 19:38 编辑

代码注释详细讲解,写这个不容易,求设最佳

  1. def open_boxs(n):
  2.     if n == 0: #判断边界条件,如果n等于0,那么就可以取出钻戒了
  3.         print("取出钻戒")
  4.         return #必须返回,否则会死递归
  5.     print("打开第", n, "层盒子") #先打开第n层盒子
  6.     open_boxs(n - 1) #再打开第n - 1层盒子

  7. def close_boxs(n):
  8.     #注:在这里,是先递归,在盖上,因为要盖上第n层盒子需要盖上n - 1层盒子
  9.     if n == 0: #判断边界条件,如果要盖上第0层盒子,说明盒子就盖完了,返回
  10.         return
  11.     close_boxs(n - 1) #盖上第n - 1层盒子
  12.     print("盖上第", n, "层盒子") #输出

  13. def main():
  14.     n = int(input("输入包装的层数: ")) #先输入
  15.     open_boxs(n) #再打开
  16.     close_boxs(n) #接着盖上
  17.     print("还原包装") #然后还原
  18.     return 0 #最后返回

  19. main()
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-26 18:27

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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