c语言函数的迭代与递归_递归与迭代

c语言函数的迭代与递归_递归与迭代斐波那契数列:11235813213455…fb(n):1n<=2fb(n-1)+fb(n-2)n>2intfb(n){if(n<=2){return1;}else{returnfb(n-1)+fb(n-2);}}使用递归需进行,如果递归的深度并不是很深,便可以使用。递归的子问题一定要有解。(即递归一定要有回归条件。)递归有两个过程…

大家好,又见面了,我是你们的朋友全栈君。

斐波那契数列:

1 1 2 3 5 8 13 21 34 55 …

fb(n) :

1 n <= 2

fb(n-1) + fb(n-2) n > 2

int fb(n)

{

if(n <= 2)

{

return 1;

}

else

{

return fb(n-1)+fb(n-2);

}

}

使用递归需进行,如果递归的深度并不是很深,便可以使用。递归的子问题一定要有解。(即递归一定要有回归条件。)

递归有两个过程:

递推:层层推进,分解问题

回归:层层回归,返回较大问题的解

递归函数的缺陷:

1.对栈的依赖性太高,需要耗费大量的栈空间来实现递推过程

2.逻辑简单,好理解。

只要是函数,都可以自己调用自己,但是,禁止main调用main函数。(即main自己调用自己)(容易产生栈的上溢。)

使用迭代来实现斐波那契数列:

int fb(n)

{

if(n <= 2)

{

return 1;

}

int n1 = 1, n2 = 1, n3 = 0;

int i = 0;

for(i = 3; i <= n; i++)

{

n3 = n1 + n2;

n1 = n2;

n2 = n3;

}

return n3;

}

递归和迭代的区别:

1.什么是递归

是一种算法思想:是将大问题分解成若干个结构相同的子问题,只有解决子问题才能求得大问题的解。我们将这样的算法思想称之为递归。

在C语言中,有一种函数,该函数可以在函数体中调用自己,这样函数称之为递归函数。

递归有两个过程:

递推

回归

2.什么是迭代

迭代是对递归的一种优化,递归将递推的过程交给了计算机,让计算机代替人去分析问题。而迭代将递推(归纳抽象解决方案)的过程交给

了程序员。进而减小了机器在递推过程中对栈的消耗,大大提高了算法效率。

3.递归的特点

1.解放了人

2.对栈的消耗大

3.算法的效率低下,不能过多层的递归

4.迭代的特点

1.需要人去分析迭代过程

2.减小的对栈的开销

3.算法的效率高

5.什么时候使用递归

1.递归层次不多

2.对于栈消耗不是很大时

6.什么时候使用迭代

如果一个问题,可以使用迭代来实现,就尽量使用迭代。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/135253.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 图解正向代理和反向代理的区别_nginx配置多个正向代理

    图解正向代理和反向代理的区别_nginx配置多个正向代理套用古龙武侠小说套路来说,代理服务技术是一门很古老的技术,是在互联网早期出现就使用的技术。一般实现代理技术的方式就是在服务器上安装代理服务软件,让其成为一个代理服务器,从而实现代理技术。常用的代理技术分为正向代理、反向代理和透明代理。本文就是针对这三种代理来讲解一些基本原理和具体的适用范围,便于大家更深入理解代理服务技术。一、正向代理(ForwardProxy)&nbs…

  • ftp常用命令详解_iftop命令详解

    ftp常用命令详解_iftop命令详解在window下按window+r可打开DOS命令窗口,然后就可以输入FTP命令了。1.登录FTP服务器方法一:直接输入ftp加ip地址ftp192.168.10.xxx方法二:直接输入ftp,进入ftp服务后输入open加ip地址open192.168.10.xxx当连接成功后会让你进行身份验证,在输入密码时屏幕上没有任何显示,不用管,直接…

  • 2021最新Java JDK1.8的安装教程

    2021最新Java JDK1.8的安装教程2021最新JavaJDK1.8安装教程(超详细)jdk1.8又称jdk8.0,是目前相对比较稳定的版本,不建议下载最新的jdk版本,因为最新版的jdk不稳定,在Java开发可能会出现各种各样的BUG。一、JDK下载1.官网下载点击官网下载地址找到自己电脑相对应的JDK,点击下载。如果不清楚自己的电脑是32位还是64位,可以找到“此电脑”,点击右键,选择属性,点开后就可以找到自己电脑位数。如图:勾选接受许可协议后点击下载会提示登录ORACLE账户,如果没有就用邮箱注册一个登录后就可以下

  • python爬虫–异步

    python爬虫–异步

  • matlab fmincon优化,求教Matlab用fmincon做优化计算

    matlab fmincon优化,求教Matlab用fmincon做优化计算本人利用fmincon做优化计算,其程序如下:1,主程序clearallx0=[0.1,0.3,0.2,0.3,0.1,45,0.214,0.05,0,0.45,0.15,0,0.4,0.12,0,0,0,0,0,0,0,0,0,0,0,0];A=[1-1-110000000000000000000000;11-1-10000…

  • Web安全之SSRF漏洞

    Web安全之SSRF漏洞内容SSRF漏洞的危害SSRF漏洞的挖掘SSRF漏洞的防御SSRF漏洞原理概述背景SSRF(Server-SideRequestForgery:服务器端请求伪造)是一种由攻击者构造形成由服务端发起请求的一个安全漏洞。一般情况下,SSRF攻击的目标是从外网无法访问的内部系统。概述很多Web应用都提供了从其他服务器上获取数据的功能。使用用户指定的URL,Web应用可以获取图片…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号