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

五、最后我想说

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

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

目录
相关文章
|
11天前
|
存储 数据挖掘 开发者
Python编程入门:从零到英雄
在这篇文章中,我们将一起踏上Python编程的奇幻之旅。无论你是编程新手,还是希望拓展技能的开发者,本教程都将为你提供一条清晰的道路,引导你从基础语法走向实际应用。通过精心设计的代码示例和练习,你将学会如何用Python解决实际问题,并准备好迎接更复杂的编程挑战。让我们一起探索这个强大的语言,开启你的编程生涯吧!
|
4天前
|
Python
Python编程入门:从零开始的代码旅程
本文是一篇针对Python编程初学者的入门指南,将介绍Python的基本语法、数据类型、控制结构以及函数等概念。文章旨在帮助读者快速掌握Python编程的基础知识,并能够编写简单的Python程序。通过本文的学习,读者将能够理解Python代码的基本结构和逻辑,为进一步深入学习打下坚实的基础。
|
8天前
|
数据采集 存储 数据处理
Python中的多线程编程及其在数据处理中的应用
本文深入探讨了Python中多线程编程的概念、原理和实现方法,并详细介绍了其在数据处理领域的应用。通过对比单线程与多线程的性能差异,展示了多线程编程在提升程序运行效率方面的显著优势。文章还提供了实际案例,帮助读者更好地理解和掌握多线程编程技术。
|
10天前
|
存储 人工智能 数据挖掘
Python编程入门:打造你的第一个程序
本文旨在为初学者提供Python编程的初步指导,通过介绍Python语言的基础概念、开发环境的搭建以及一个简单的代码示例,帮助读者快速入门。文章将引导你理解编程思维,学会如何编写、运行和调试Python代码,从而开启编程之旅。
34 2
|
11天前
|
存储 Python
Python编程入门:理解基础语法与编写简单程序
本文旨在为初学者提供一个关于如何开始使用Python编程语言的指南。我们将从安装Python环境开始,逐步介绍变量、数据类型、控制结构、函数和模块等基本概念。通过实例演示和练习,读者将学会如何编写简单的Python程序,并了解如何解决常见的编程问题。文章最后将提供一些资源,以供进一步学习和实践。
25 1
|
14天前
|
存储 网络协议 IDE
从零起步学习Python编程
从零起步学习Python编程
|
13天前
|
机器学习/深度学习 存储 数据挖掘
Python 编程入门:理解变量、数据类型和基本运算
【10月更文挑战第43天】在编程的海洋中,Python是一艘易于驾驭的小船。本文将带你启航,探索Python编程的基础:变量的声明与使用、丰富的数据类型以及如何通过基本运算符来操作它们。我们将从浅显易懂的例子出发,逐步深入到代码示例,确保即使是零基础的读者也能跟上步伐。准备好了吗?让我们开始吧!
24 0
|
7月前
|
算法 Python 容器
Python编程 - 不调用相关choose库函数,“众数“挑选器、随机挑选器 的源码编程实现
Python编程 - 不调用相关choose库函数,“众数“挑选器、随机挑选器 的源码编程实现
89 0
|
3月前
|
算法 Python
Python编程的函数—内置函数
Python编程的函数—内置函数
19 0
|
7月前
|
算法 Python
Python编程实验四:函数的使用
Python编程实验四:函数的使用
100 0