Python编程基础:实验6——函数的递归

简介: 有关Python函数递归的一些题目,非常经典,开箱即用。

一、前言

本期博客主要练习有关函数的递归方法,函数的递归有很多经典的例子,在这里我就写一下老师提供的几个题目,如果还想继续做相关题目的话,大家可以去力扣上面刷题。

注意:代码仅供参考,还请大家多多思考!

二、我的环境

  • 电脑系统:Windows 11
  • 语言版本:Python 3.10.4
  • 编译器:VSCode

三、实验目的与要求

  1. 掌握函数递归的定义和使用方法
  2. 理解实验中的经典递归算法思想

四、实验任务

1、程序填空

【填空8-1】采用递归思想,编程求斐波那契数列的指定项,指定项由键盘输入,请在代码的横线处补充。

斐波那契数列的公式是:

20200410170206910.png

如下是斐波那契数列计算过程的动态图:

2-210R0100005236.gif

deffibonacci(n):
ifn>2:
returnfibonacci(n-1) +fibonacci(n-2)
elifn==2:
return1elifn==1:
return1x=eval(input("Input x="))
print(fibonacci(x))

它运行的结果是:

Inputx=1055

如果要显示斐波那契数列数列的前n项,n由键盘输入,我们可以这样修改以上程序来实现:

deffibonacci(n):
ifn>2:
returnfibonacci(n-1) +fibonacci(n-2)
elifn==2:
return1elifn==1:
return1x=eval(input("Input x="))
print(fibonacci(x))
foriinrange(1, x+1) :
print(fibonacci(i), end=" ")

它运行的结果是:

Inputx=105511235813213455

【填空8-2】采用递归思想,以二分法查找有序列表的指定值,请在代码的横线处补充。

如下是二分法原理图:

v2-6251fe5159bb30c0d34b3eeebd4257d3_b.png

defdichotomy(alist, item):
iflen(alist) ==0:     # 查找范围为空返回找不到FalsereturnFalseelse:
midpoint=len(alist) //2# 求查找范围的中间点ifalist[midpoint] ==item:
returnTrueelse:
# 待查值小于中间点,即缩小查找范围为中间点左半侧ifitem<alist[midpoint]:
returndichotomy(alist[: midpoint] , item)
# 待查值大于中间点,即缩小查找范围为中间点右半侧else:
returndichotomy(alist[midpoint+1:], item)
testlist= [0, 1, 2, 8, 13, 17, 19, 32, 42]
print(dichotomy(testlist, 3))
print(dichotomy(testlist, 13))

它运行的结果是:

FalseTrue

2、程序编程

【编程8-1】采用递归思想,将一个正整数倒序输出,例如给出正整数n=12345,即输出54321。

提示:首先输出这个数的个位数,然后再输出前面数字的个位数,直到之前没有数字为止。

首先递归表达式是:

函数递归.jpg

rev_num=0base_pos=1defreversDigits(n):
globalrev_numglobalbase_posif(n>0):
reversDigits(int(n/10))
rev_num+= (n%10) *base_posbase_pos*=10returnrev_numn=eval(input("请给出正整数n="))
print("倒序输出后结果是:",reversDigits(n))

它运行的结果是:

请给出正整数n=12345倒序输出后结果是:54321

五、最后我想说

本期内容就涉及到了函数递归的相关算法,我们首先要去理解它的原理才能更好更快的写出对应的程序,所以还是很有必要去看一下相关的数学原理。

除了上面所提到的题目,还有很多经典的例子,比如汉诺塔、数的阶乘等等,网上有很多,各种语言版本都有,大家可以去看一看,然后练一练,毕竟熟能生巧。

目录
相关文章
|
7天前
|
算法 程序员 开发工具
百万级Python讲师又一力作!Python编程轻松进阶,豆瓣评分8.1
在学习Python的旅程中你是否正在“绝望的沙漠”里徘徊? 学完基础教程的你,是否还在为选择什么学习资料犹豫不决,不知从何入手,提高自己?
百万级Python讲师又一力作!Python编程轻松进阶,豆瓣评分8.1
|
1天前
|
Shell 数据处理 C++
【震撼揭秘】Python正则VS Shell正则:一场跨越编程边界的史诗级对决!你绝不能错过的精彩较量,带你领略文本处理的极致魅力!
【8月更文挑战第19天】正则表达式是文本处理的强大工具,在Python与Shell中有广泛应用。两者虽语法各异,但仍共享许多基本元素,如`.`、`*`及`[]`等。Python通过`re`模块支持丰富的功能,如非捕获组及命名捕获组;而Shell则依赖`grep`、`sed`和`awk`等命令实现类似效果。尽管Python提供了更高级的特性和函数,Shell在处理文本文件方面仍有其独特优势。选择合适工具需根据具体需求和个人偏好决定。
|
5天前
|
算法 程序员 开发工具
百万级Python讲师又一力作!Python编程轻松进阶,豆瓣评分8.1
在学习Python的旅程中你是否正在“绝望的沙漠”里徘徊? 学完基础教程的你,是否还在为选择什么学习资料犹豫不决,不知从何入手,提高自己?
|
3天前
|
数据采集 存储 人工智能
掌握Python编程:从基础到进阶的实用指南
【8月更文挑战第17天】 本文旨在通过浅显易懂的语言和实际案例,为初学者和有一定基础的开发者提供一条清晰的Python学习路径。我们将从Python的基本语法入手,逐步深入到面向对象编程、数据科学应用及网络爬虫开发等高级主题。每个部分都配备了代码示例和实操建议,确保读者能够将理论知识转化为实际能力。无论你是编程新手,还是希望提升Python技能的开发者,这篇文章都将为你打开一扇通往高效编程世界的大门。
7 2
|
3天前
|
存储 缓存 算法
Python中的hash函数
Python中的hash函数
|
6天前
|
Python
Python学习笔记---函数
这篇文章是一份Python函数学习的笔记,涵盖了使用函数的优势、内置函数的调用、自定义函数的定义、函数参数的不同类型(必须参数、关键字参数、默认参数、可变参数)、有返回值和无返回值的函数、形参和实参、变量作用域、返回函数、递归函数、匿名函数、偏函数以及输入和输出函数等多个函数相关的主题。
|
1天前
|
机器学习/深度学习 Ubuntu 数据挖掘
揭秘:Ubuntu系统下部署Anaconda环境及Python语言的终极指南!跟随这一步步神秘流程,解锁编程大师的秘密武器!
【8月更文挑战第19天】在Ubuntu中部署Anaconda环境与Python相当直观。首先需从官网下载Linux版安装包。接着,在终端依次执行命令:添加Anaconda清华镜像源至软件源列表,更新软件包信息,然后安装Anaconda。安装后可通过`anaconda --version`验证。使用`anaconda create -n myenv python=3.8`创建名为“myenv”的环境并指定Python 3.8版本。
|
5天前
|
Python
Python 函数
Python 函数
7 0
|
3月前
|
算法 Python 容器
Python编程 - 不调用相关choose库函数,“众数“挑选器、随机挑选器 的源码编程实现
Python编程 - 不调用相关choose库函数,“众数“挑选器、随机挑选器 的源码编程实现
58 0
|
3月前
|
存储 程序员 Shell
Python 进阶指南(编程轻松进阶):十、编写高效函数
Python 进阶指南(编程轻松进阶):十、编写高效函数
57 0