递归,递推,迭代区别

2023-05-16

程序调用自身的编程技巧称为递归( recursion)。递归做为一种算法在程序设计语言中广泛应用。 一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。递归的能力在于用有限的语句来定义对象的无限集合。一般来说,递归需要有边界条件、递归前进段和递归返回段。当边界条件不满足时,递归前进;当边界条件满足时,递归返回。——摘自百度百科

递推算法是一种用若干步可重复的简运算(规律)来描述复杂问题的方法。递推是序列计算机中的一种常用算法。它是按照一定的规律来计算序列中的每个项,通常是通过计算机前面的一些项来得出序列中的指定象的值。

迭代重复反馈过程的活动,俗称循环,其目的通常是为了逼近所需目标或结果。每一次对过程的重复称为一次“迭代”,而每一次迭代得到的结果会作为下一次迭代的初始值 

迭代举例:用迭代法求平方根
代码如下:

#include<stdio.h>
#include<math.h>
int main(){
   float a,x0,x1;
   int i=0;
   printf("enter a positive number:");
   scanf("%f",&a);
   x0=a/2;   //给x赋初值(也可以是另外的值)
   x1=(x0+a/x0)/2;
   do
   {   i++;
	   x0=x1;
	   x1=(x0+a/x0)/2;
   }while(fabs(x0-x1)>=1e-5);
   printf("%f的平方根为:%f\n",a,x1);
   printf("%d",i);
   return 0;
}
 


简单来说,关于递推和递归,概念如下:

 void digui()
{
    if(你不懂)    digui();
    if(你懂了)    return  hehe;
}
void ditui()
{
   if(你没懂)  ditui();
   if(你懂了)  cout<<"hehe";
}

 

举例:
1.

小猴子第一天摘下若干桃子,当即吃掉一半,又多吃一个.第二天早上又将剩下的桃子吃一半,又多吃一个.以后每天早上吃前一天剩下的一半另一个.到第10天早上猴子想再吃时发现,只剩下一个桃子了.问第一天猴子共摘多少个桃子?

有雌雄一对兔子,假定过两个月便可繁殖雌雄各一的一对小兔子。问过n个月后共有多少对兔子?

这是著名的斐波那契数列= =递推必刷题之一,当然还有很多关于这道题的难题,暂时不一一列举

3.角谷定理。输入一个自然数,若为偶数,则把它除以2,若为奇数,则把它乘以3加1。经过如此有限次运算后,总可以得到自然数值1。求经过多少次可得到自然数1。 如:输入22, 输出

22 11 34 17 52 26 13 40 20 10 5 16 8 4 2 1

第二部分 递推与迭代

递推法与迭代法

递推:Un=Un-1*2

迭代:y=x*2;x=y;
  如果就这两个式子来编程的话,递推会用到递归函数或生成一个长为n数组但如果是迭代,就只会用到一个while或for循环,而且只用2个变量,程序的效率比递推法要高。应该是因为迭代法是在递推法的基础上再进一步的分析,以得到便于编程解决的式子。
  迭代算法是用计算机解决问题的一种基本方法。它利用计算机运算速度快、适合做重复性操作的特点,让计算机对一组指令(或一定步骤)进行重复执行,在每次执行这组指令(或这些步骤)时,都从变量的原值推出它的一个新值。
  利用迭代算法解决问题,需要做好以下三个方面的工作:
  一、确定迭代变量。在可以用迭代算法解决的问题中,至少存在一个直接或间接地不断由旧值递推出新值的变量,这个变量就是迭代变量。
  
  二、建立迭代关系式。所谓迭代关系式,指如何从变量的前一个值推出其下一个值的公式(或关系)。迭代关系式的建立是解决迭代问题的关键,通常可以使用递推或倒推的方法来完成。
  
  三、对迭代过程进行控制。在什么时候结束迭代过程?这是编写迭代程序必须考虑的问题。不能让迭代过程无休止地重复执行下去。迭代过程的控制通常可分为两种情况:一种是所需的迭代次数是个确定的值,可以计算出来;另一种是所需的迭代次数无法确定。对于前一种情况,可以构建一个固定次数的循环来实现对迭代过程的控制;对于后一种情况,需要进一步分析出用来结束迭代过程的条件。

小结:
递归与循环:
从理论上说,所有的递归函数都可以转换为迭代函数,反之亦然,然而代价通常都是比较高的。当递归次数较多时,内存占用也会随之增加。
递推与递归:

从程序上看,递归表现为自己调用自己,递推则没有这样的形式。
递归是从问题的最终目标出发,逐渐将复杂问题化为简单问题,最终求得问题
是逆向的。递推是从简单问题出发,一步步的向前发展,最终求得问题。是正向的。
递归中,问题的n要求是计算之前就知道的,而递推可以在计算中确定,不要求计算前就知道n。
一般来说,递推的效率高于递归(当然是递推可以计算的情况下)
用递归考虑问题,非递归方式编写
迭代:利用变量的原值推算出变量的一个新值.如果递归是自己调用自己的话,迭代就是A不停的调用B.
递归中一定有迭代,但是迭代中不一定有递归,大部分可以相互转换.能用迭代的不用递归,递归调用函数,浪费空间,并且递归太深容易造成堆栈的溢出
详见 迭代与递归

#include<stdio.h>
int main()
{
	double f[100];
	f[1]=1, f[2]=1;
	for(int i=3; i<=50; i++)
	{
		f[i]=f[i-1]+f[i-2];
	}
	int n;
	scanf("%d",&n);
	printf("%.10lf\n",f[n]/f[n+1]);
 } 

2. 循环实现(简单高效)

2.1 for循环实现 

代码

#include <stdio.h>
int fib(int input) {
	int f1 = 1, f2 = 1, f3 = 1;
	for (int i = 2; i < input;i++) {
		f3 = f1 + f2;
		f1 = f2;
		f2 = f3;
	}
	return f3;
}
void main() {
	int input = 0;
	scanf("%d",&input);
	printf("第%d位斐波那契数为:%d",input,fib(input));
}

 

 

 

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

递归,递推,迭代区别 的相关文章

  • 四、FreeRTOS学习之 队列

    目录 1 定义 2 函数介绍 1 队列创建 2 队列删除 3 写队列 4 读队列 3 实例 1 定义 队列是freertos所有任务通信或同步之外的机制 xff0c 队列包含多个数据称为长度 xff0c 每个数据大小相同 xff0c 创建队
  • 静态和动态控制数码管-第1季第7部分-朱有鹏-专题视频课程

    静态和动态控制数码管 第1季第7部分 2313人已学习 课程介绍 本课程是 朱有鹏老师单片机完全学习系列课程 第1季第7个课程 xff0c 全面讲解了静态数码管 无38译码器式动态数码管 有38译码器式动态数码管等各种数码管驱动方式 xff
  • MapReduce原理讲解(带源码)

    在MapReduce 中运行的job 类里 xff0c 最先出现的就是FileInputFormat 类 xff0c 它继承于InputFormat 一 InputFormat xff1a 这是一个重要的抽象类 xff0c 其中包括两个抽象
  • 弯管机程序使用三菱FX系列 PLC和昆仑通态触摸屏,也可以用三菱F940系列触摸屏

    弯管机程序使用三菱FX系列 PLC和昆仑通态触摸屏 xff0c 也可以用三菱F940系列触摸屏 ID 85200637609016631猫猫工控
  • [Vue warn]:Missing required prop: “value” 报错的解决办法

    报错场景 在vue中使用element ui的el select标签报错 Vue warn Missing required prop 34 value 34 出现问题的原因 1 el select标签没有使用v model绑定值 lt 没
  • 常用组合逻辑电路及MSI组合电路模板的应用——下篇

    一 加法器 计算机诞生的起因便是计算导弹轨道 xff0c 因此计算是必经之路 如何实现两个二进制数的相加呢 xff1f 在C语言操作符一节中 xff0c 我们曾经利用与运算和异或运算 xff0c 加上循环移位 xff0c 实现了两个二进制数
  • 物联网平台搭建的全过程介绍(二)——物联网平台通信思维导图

    目前物联网平台很多 xff0c 本例以阿里云物联网平台为例 xff0c 介绍一下物联网平台通信的思维导图和实现的步骤 xff0c 本文仅做功能的宏观描述 xff0c 具体操作会在后续文章内详细介绍 其他物联网原理基本大同小异 思维导图如下图
  • web 前端的浏览器

    1 浏览器及内核 web浏览器是用于读取HTML文件 xff0c 并将其作为网页显示 浏览器最重要的部分或其核心是渲染引擎 xff0c 我们一般称为内核 xff1b 内核的作用负责对网页语法的解释并渲染网页 xff1b 五大浏览器 xff1
  • C++的第一个代码“Hello World!”

    代码展示 include lt iostream gt include lt cstdio gt using namespace std int main printf 34 Hello World n 34 printf 34 1 Def
  • C.刷oj1026有感

    1 if嵌套 if 条件1 语句1 if 条件2 语句2 if 条件3 语句3 语句4 诸如这样嵌套 xff0c 要先判断条件1是否成立 xff0c 如果成立 xff0c 执行语句1 xff0c 再继续下面操作 如果条件1不成立 xff0c
  • C.刷oj1037有感

    不能判断浮点数相等或不相等 xff01 因为浮点数是对实数的近似表达 如 double y if y 61 61 0 这样是错的 xff01 1 判断浮点数是否为0的方法 fabs y lt 1e 10 2 判断两个浮点数是否相等的方法 f
  • 逻辑或、与运算的短路

    假定i 61 5 j 61 5 i 43 43 xff1c xff1d 5 j 43 43 xff1c xff1d 5 首先这个表达式的结果为1 真 xff0c 但执行完这个表达式后i的值为6 xff0c j的值不变 xff0c 为5 xf
  • LED点阵-第1季第8部分-朱有鹏-专题视频课程

    LED点阵 第1季第8部分 1818人已学习 课程介绍 本课程是 朱有鹏老师单片机完全学习系列课程 第1季第8个课程 xff0c 讲解了16 16LED点阵的驱动方式和文字显示 本课程的学习目标是理解点阵式LED屏幕的驱动方式 74HC59
  • C语言声明变量时的小细节

    声明变量时不能连续赋值 xff0c 例如 int a 61 b 61 0 这样编译器会报错 xff1a b没有声明 可以在声明变量时给一个变量赋值 int a 61 0 int a b c d 61 0 或 int a b c 61 0 d
  • C.for循中表达式的省略

    省略第一个表达式 for 表达式2 表达式3 注意第一个分号不能省 xff01 xff01 xff01 省略第二个表达式 for 表达式1 表达式3 死循环 省略第三个 for 表达式1 表达式2 最后的表达式的分号就不要了 可以在循环体内
  • C语言新收获

    if x 语句3 表达式是变量 xff0c 如果x不等于0 xff0c 则条件判断结果为真 xff0c 执行语句3 if 1 语句4 表达式是非0整数 条件判断结果为真 xff0c 执行语句4 if 0 语句5 表达式是整数0 xff0c
  • C语言新收获

    若a 61 3 xff0c b 61 2 xff0c c 61 1 xff0c 则 d 61 a gt b xff0c 由于a gt b为真 xff0c 因此关系表达式a gt b的值为1 xff0c 所以赋值后d的值为1 f 61 a g
  • C语言swith语句小细节

    1 swtich 中的 里的数据只能为整形或字符型 xff0c 不能为浮点型 xff01 2 swith x xff5b case 1 语句1 case 2 xff1a 语句2 case 3 语句3 xff1b break case 4 语
  • switch语句每个csse后面可以跟多个值吗

    如果今天是星期三 xff0c 后天就是星期五 xff1b 如果今天是星期六 xff0c 后天就是星期一 我们用数字1到7对应星期一到星期日 给定某一天 xff0c 请你输出那天的 后天 是星期几 输入格式 xff1a 输入第一行给出一个正整

随机推荐

  • c学习笔记

    指针之间可以比较大小 xff0c 前提是两个指针指向同一数组 如 char a 20 xff1b char p1 61 a 43 1 char p2 61 a 43 2 则p2 gt p1
  • zzulioj1150

    数数多少个整数 题目描述 小明的老师给小明出了一道题目 xff1a 数数一篇文章出现了多少个数字 xff0c 请你帮帮他吧 输入 输入一个字符串 xff0c 由空格 英文字母 数字组成 xff0c 以回车结束 xff0c 长度小于1000
  • 1152: 二分搜索

    题目描述 在有序序列中查找某一元素x 输入 首先输入一个正整数n n lt 61 100000 xff0c 表示该序列有n个整数 xff0c 然后按从小到大的顺序输入n个整数 xff1b 接着是一个正整数m xff0c 表示有m次查找 xf
  • C语言反思提醒自己

    例如 xff1a char fun char p char s 101 return s 这样将不能正确返回字符串s xff0c 因为在离开fun 函数后该内存空间将不再存在 xff0c 应该使用malloc函数申请内存 xff0c 该函数
  • 按键-第1季第9部分-朱有鹏-专题视频课程

    按键 第1季第9部分 1716人已学习 课程介绍 本课程是 朱有鹏老师单片机完全学习系列课程 第1季第9个课程 xff0c 综合解决了独立按键和矩阵式按键的处理方法 xff0c 涉及到 xff1a IO的输入输出 按键抖动和消抖 中断的引入
  • C语言反思提醒自己

    int a scanf 34 d 34 amp a 当键入07时 xff0c a中存的是7 xff0c 自动舍弃前导0
  • zzulioj1168(账单)

    题目描述 每到月末 xff0c 小明就会对这个月的支出账单进行整理和统计 如今电脑已经普及大学校园 xff0c 所以小明想让电脑帮忙做这件事情 聪明的你就为小明编一个程序来完成这件事情吧 输入 多实例测试 首先输入一个整数ncase xff
  • 总结java中关于继承中的成员属性和成员方法的多态细节

    问题背景 xff1a 下面的代码会输出什么 xff1f 40还是20 xff1f public class Animal public int age 61 40 public void eat System out println 34
  • 【java】浅谈instanceof关键字

    作用 xff1a 用于判断某个对象是否是某个特定类或该特定类的一个实例 返回一个布尔类型 一般格式 object instanceof class class可以是类也可以是接口 xff09 具体使用 xff1a 分编译阶段和运行阶段 xf
  • zzulioj 1185: 添加记录(结构体专题)

    题目描述 有一学生成绩表 xff0c 包括学号 姓名 3门课程成绩 已知该成绩表按学号升序排序 请编程实现 xff0c 添加一个新的学生信息 xff0c 且使成绩表仍按学号有序 xff1b 若待添加的学号与已有学号重复 xff0c 则输出错
  • 初学Java小细节自总

    1 如果子类的构造方法中没有显示地调用父类的构造方法 xff0c 那么Java编译器会自动在子类的构造方法中插入一条默认的super 语句 xff0c 来调用父类的无参构造方法 因此 xff0c 如果父类没有提供无参构造方法 xff0c 而
  • 如何配置Java的环境变量

    1 找到电脑的环境变量 xff08 直接在电脑左下角放大镜搜环境变量即可 xff09 xff1a 2 在环境变量的系统变量里新建一个名称为 xff1a JAVA HOME变量值为jdk的安装目录 xff08 直接点浏览目录去找jdk的安装根
  • 字符集、ASCII、GBK、UTF-8、Unicode、乱码、字符编码、解码问题

    首先计算机是美国人发明的用来处理数据的 xff0c 那么问题来了美国人如何和计算机交流呢 xff1f 怎么把他们的字符存储到计算机里面呢 美国需要存储的字符仅仅只是一些英文大小写 xff0c 数字 xff0c 标点 xff0c 和一些特殊字
  • 1022: 三整数排序(利用三目运算符可以使程序更加简洁)

    从键盘输入三个整数x y和z xff0c 按从大到小的顺序输出它们的值 输入 输入三个整数x y和z 输出 按从大到小的顺序输出它们的值 样例输入 复制 20 16 18 样例输出 复制 20 18 16 自己的思路 xff1a 首先找到最
  • 1025: 最大字符(scanf输入问题以及gets()和getchar()和scanf()的区别)

    给你三个ASCII字符 不含空白字符 包括空格 制表符 t 回车换行符 n xff0c 找出其中最大的那个 输入 输入包含三个字符 xff0c 之间有一个空格隔开 输出 输出ASII码最大的那个字符 xff0c 占一行 样例输入 复制 a
  • 定时器和计数器-第1季第10部分-朱有鹏-专题视频课程

    定时器和计数器 第1季第10部分 1573人已学习 课程介绍 本课程是 朱有鹏老师单片机完全学习系列课程 第1季第10个课程 xff0c 主要内容是51单片机的定时器和计数器 xff0c 本课程的学习目标是对定时器的作用和意义有深入理解 x
  • 1037: 四则运算(易错:浮点数不能使用==或者!=)

    给你一个简单的四则运算表达式 xff0c 包含两个实数和一个运算符 xff0c 请编程计算出结果 输入 表达式的格式为 xff1a s1 op s2 xff0c s1和s2是两个实数 xff0c op表示的是运算符 43 xff0c 也可能
  • 1053: 正弦函数

    内存限制 xff1a 30 MB时间限制 xff1a 1 000 S 题目描述 输入x xff0c 计算上面公式的前10项和 输入 输入一个实数x 输出 输出一个实数 xff0c 即数列的前10项和 xff0c 结果保留3位小数 样例输入
  • 【无标题】

    递归算法的设计要素 递归思维是一种从下向上的思维方式 xff0c 使用递归算法往往可以简化我们的代码 xff0c 而且还帮我们解决了很复杂的问题 递归算法的难点就在于它的逻辑性 xff0c 一般设计 递归算法需要考虑以下几点 明确递归的终止
  • 递归,递推,迭代区别

    程序调用自身的编程技巧称为递归 xff08 recursion xff09 递归做为一种算法在程序设计语言中广泛应用 一个过程或函数在其定义或说明中有直接或间接调用自身的一种方法 xff0c 它通常把一个大型复杂的问题层层转化为一个与原问题