实例 26

题目

利用递归方法求 5!。

分析

递归公式:Python3 编程实例(26 - 30) - 图1%20%3D%20f(n%20-%201)%20*%20n#card=math&code=f%28n%29%20%3D%20f%28n%20-%201%29%20%2A%20n&id=S10UN);

代码

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # @version : 1.0
  4. # @Time : 2021/4/10 10:07
  5. # @Author : cunyu
  6. # @Email : 747731461@qq.com
  7. # @Site : https://cunyu1943.site
  8. # 公众号 : 村雨遥
  9. # @File : 26.py
  10. # @Software: PyCharm
  11. # @Desc : 练习实例26
  12. def fact(num):
  13. if num == 0:
  14. return 1
  15. else:
  16. return fact(num - 1) * num
  17. if __name__ == '__main__':
  18. print(fact(5))

结果

Python3 编程实例(26 - 30) - 图2

实例 27

题目

利用递归函数调用方式,将所输入的 5 个字符,以相反顺序打印出来。

分析

注意边界条件(即字符串长度为 0 时);

代码

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # @version : 1.0
  4. # @Time : 2021/4/10 10:09
  5. # @Author : cunyu
  6. # @Email : 747731461@qq.com
  7. # @Site : https://cunyu1943.site
  8. # 公众号 : 村雨遥
  9. # @File : 27.py
  10. # @Software: PyCharm
  11. # @Desc : 练习实例27
  12. def reverseString(str, length):
  13. if (length == 0):
  14. return
  15. print(str[length - 1], end='')
  16. reverseString(str, length - 1)
  17. if __name__ == '__main__':
  18. str = input("输入字符串\n")
  19. reverseString(str, len(str))

结果

Python3 编程实例(26 - 30) - 图3

实例 28

题目

有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁。问第4个人岁数,他说比第3个人大2岁。问第三个人,又说比第2人大两岁。问第2个人,说比第一个人大两岁。最后问第一个人,他说是10岁。请问第五个人多大?

分析

利用递归的方法,递归分为回推和递推两个阶段。要想知道第五个人岁数,需知道第四人的岁数,依次类推,推到第一人(10岁),再往回推。

代码

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # @version : 1.0
  4. # @Time : 2021/4/10 10:16
  5. # @Author : cunyu
  6. # @Email : 747731461@qq.com
  7. # @Site : https://cunyu1943.site
  8. # 公众号 : 村雨遥
  9. # @File : 28.py
  10. # @Software: PyCharm
  11. # @Desc : 练习实例28
  12. def age(num):
  13. if num == 1:
  14. return 10
  15. else:
  16. return 2 + age(num - 1)
  17. if __name__ == '__main__':
  18. print("第五个人的年龄:" + str(age(5)))

结果

Python3 编程实例(26 - 30) - 图4

实例 29

题目

给一个不多于5位的正整数,要求:一、求它是几位数,二、逆序打印出各位数字。

分析

重点在于如何将这个正整数分解,然后再逆序打印即可;

代码

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # @version : 1.0
  4. # @Time : 2021/4/10 10:19
  5. # @Author : cunyu
  6. # @Email : 747731461@qq.com
  7. # @Site : https://cunyu1943.site
  8. # 公众号 : 村雨遥
  9. # @File : 29.py
  10. # @Software: PyCharm
  11. # @Desc : 练习实例29
  12. if __name__ == '__main__':
  13. num = int(input("输入一多于 5 位的正整数\n"))
  14. one = num % 10
  15. ten = num % 100 // 10
  16. hundred = num % 1000 // 100
  17. thousand = num % 10000 // 1000
  18. million = num // 10000
  19. if million != 0:
  20. print("5 位数:", one, ten, hundred, thousand, million)
  21. elif thousand != 0:
  22. print("4 位数:", one, ten, hundred, thousand)
  23. elif hundred != 0:
  24. print("3 位数:", one, ten, hundred)
  25. elif ten != 0:
  26. print("2 位数:", one, ten)
  27. elif one != 0:
  28. print("1 位数:", one)

结果

Python3 编程实例(26 - 30) - 图5

实例 30

题目

一个 5 位数,判断它是不是回文数。即 12321 是回文数,个位与万位相同,十位与千位相同。

分析

和上一个例子一样,重点在于分解该整数,然后再判断个位和万位,十位和千位是否相同;

代码

  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. # @version : 1.0
  4. # @Time : 2021/4/10 10:30
  5. # @Author : cunyu
  6. # @Email : 747731461@qq.com
  7. # @Site : https://cunyu1943.site
  8. # 公众号 : 村雨遥
  9. # @File : 30.py
  10. # @Software: PyCharm
  11. # @Desc : 练习实例30
  12. if __name__ == '__main__':
  13. num = int(input("输入一个 5 位的正整数\n"))
  14. one = num % 10
  15. ten = num % 100 // 10
  16. hundred = num % 1000 // 100
  17. thousand = num % 10000 // 1000
  18. million = num // 10000
  19. if one == million and ten == thousand:
  20. print("%d 是一个回文数" % num)
  21. else:
  22. print("%d 不是一个回文数" % num)

结果

Python3 编程实例(26 - 30) - 图6