java里递归和迭代分别是什么算法啊
迭代是普通的循环。
例:求从1加到10
int sum=0
for(int i=0;i<= 10;i++){
sum=sum+i;
}
递归是指一个函数直接或间接调用自己。
好比:从前有个庙庙里有个大和尚和小和尚,大和尚叫小和尚讲故事,小和尚说从前有个庙庙里有个大和尚和小和尚,小和尚叫大和尚讲故事,大和尚说从前....
递归的特点:
必有三个条件:
1. 间接或直接调用自己。
2. 一定要有退出的条件(比方说大和尚口干了不听故事了)。
否则就是死循环
3。
要有逻辑体(想要做的事);
public int sum(int x){
if(x<=0){
return x;
}
return x+sum(x-1);
}
int s=10;
int total=sum(s);
该例中,sum函数总是调用自己,return x+sum(x-1);
sum有退出条件, x<=0
最后的结果是把 10+9+8+7+... 1 返回
在很多种情况下,迭代和递归都可以完成相同的功能, 不过递归有些功能迭代就完成不了。
并且代码没有递归简洁,熟练使用递归后能提高代码质量。
递推,递归,迭代分别是啥意思,希望能分别
递推是按照一定的规律来计算序列中的每个项,通常是通过计算前面的一些项来得出序列中的指定项的值。
其思想是把一个复杂的庞大的计算过程转化为简单过程的多次重复。
例:十本不同的书放在书架上。
现重新摆放,使每本书都不在原来放的位置。
有几种摆法?
当n个编号元素放在n个编号位置,元素编号与位置编号各不对应的方法数用M(n)表示,那么M(n-1)就表示n-1个编号元素放在n-1个编号位置,各不对应的方法数,其它类推.
第一步,把第n个元素放在一个位置,比如位置k,一共有n-1种方法;
第二步,放编号为k的元素,这时有两种情况.1,把它放到位置n,那么,对于剩下的n-2个元素,就有M(n-2)种方法;2,不把它放到位置n,这时,对于这n-1个元素,有M(n-1)种方法;
综上得到
M(n)=(n-1)[M(n-2)+M(n-1)]
递推算法以初始(起点)值为基础,用相同的运算规律,逐次重复运算,直至运算结束。
这种从“起点”重复相同的方法直至到达一定“边界”,犹如单向运动,用循环可以实现。
递推的本质是按规律逐次推出(计算)先一步的结果。
递归,就是在运行的过程中调用自己。
构成递归需具备的条件:
1. 子问题须与原始问题为同样的事,且更为简单;
2. 不能无限制地调用本身,须有个出口,化简为非递归状况处理。
例: 楼梯有n阶台阶,上楼可以一步上1阶,也可以一步上2阶,编一程序计算共有多少种不同的走法.
设n阶台阶的走法数为f(n),显然有:
1 n=1
2 n=2
f(n-1)+f(n-2) n>2
算法为:当n>2时函数f(n)返回f(n-1)+f(n-2);
当n=2时函数f(n)返回2
当n=1时函数f(n)返回1
迭代是重复反馈过程的活动,其目的通常是为了逼近所需目标或结果。
每一次对过程的重复称为一次“迭代”,而每一次迭代得到的结果会作为下一次迭代的初始值。
例:一个饲养场引进一只刚出生的新品种兔子,这种兔子从出生的下一个月开始,每月新生一只兔子,新生的兔子也如此繁殖。
如果所有的兔子都不死去,问到第 12 个月时,该饲养场共有兔子多少只?
分析:这是一个典型的递推问题。
我们不妨假设第 1 个月时兔子的只数为 u 1 ,第 2 个月时兔子的只数为 u 2 ,第 3 个月时兔子的只数为 u 3 ,……根据题意,“这种兔子从出生的下一个月开始,每月新生一只兔子”,则有:
u 1 = 1 , u 2 = u 1 + u 1 × 1 = 2 , u 3 = u 2 + u 2 × 1 = 4 ,……
根据这个规律,可以归纳出下面的递推公式:
u n = (u n - 1) × 2 (n ≥ 2)* ①
对应 u n 和 u n - 1 ,定义两个迭代变量y 和 x ,可将上面的递推公式转换成如下迭代关系:
①y=x*2
②x=y
①②两步反复迭代,就可以求出第12个月时兔子的总数了。
算法中的“迭代”和“递归有什么区别
区别很大,两个根本不是一回事:
迭代,多数用于类似集合这样的,遍历!怎么打个比方才好理解呢....纠结了...
迭代你就理解成遍历,不过这个遍历特殊之处就是:
第一:它会限制一些操作,比如说修改元素之类的操作..
第二:迭代内部会有一个指针,假如你正向迭代,这个指针会每次前移一次,不会后退,意思也就是说不会像for循环那样,可以控制;反向迭代也是同理,指针会每次后退一下!
递归:你可以简单点理解成:
一个函数调用自己,但是递归的前提一定要有终止条件,否者会栈内存溢出,然后就是循环体了!递归和迭代的区别有哪些
递归是不断的压栈。
非常消耗内存。
是相当于一种解决事物的算法。
不断的执行相同的函数代码,类似的可以解决汉诺塔等问题。
而迭代你可以理解为取出容器里东西的方法。
SoftShellWeb是一家2019年成立的国外主机商,商家在英格兰注册,提供的产品包括虚拟主机和VPS,其中VPS基于KVM架构,采用SSD硬盘,提供IPv4+IPv6,可选美国(圣何塞)、荷兰(阿姆斯特丹)和台湾(台北)等机房。商家近期推出台湾和荷兰年付特价VPS主机,其中台湾VPS最低年付49美元,荷兰VPS年付24美元起。台湾VPSCPU:1core内存:2GB硬盘:20GB SSD流量...
主机参考最新消息:JustHost怎么样?JustHost服务器好不好?JustHost好不好?JustHost是一家成立于2006年的俄罗斯服务器提供商,支持支付宝付款,服务器价格便宜,200Mbps大带宽不限流量,支持免费更换5次IP,支持控制面板自由切换机房,目前JustHost有俄罗斯5个机房可以自由切换选择,最重要的还是价格真的特别便宜,最低只需要87卢布/月,约8.5元/月起!just...
Advinservers,国外商家,公司位于新泽西州,似乎刚刚新成立不久,主要提供美国和欧洲地区VPS和独立服务器业务等。现在有几款产品优惠,高达7.5TB的存储VPS和高达3.5TBDDoS保护的美国纽约高防服务器,性价比非常不错,有兴趣的可以关注一下,并且支持Paypal付款。官方网站点击直达官方网站促销产品第一款VPS为预购,预计8月1日交付。CPU为英特尔至强 CPU(X 或 E5)。官方...
递归迭代为你推荐
操作http德国iphone禁售令德国买iPhone现在多少钱?企业建网站我想建立一个企业网站,需要多少钱??googlepr百度权重和googlePR都是些什么东西??outlookexpress如何开启OUTLOOK EXPRESS功能?支付宝调整还款日支付宝调整花呗还款日,这个调整有没有对你造成什么影响?字节跳动回应TikTok易主#北京字节跳动科技有限公司#小说审核有三面么?我面试了两轮就叫我回家等消息了 要是刷下来了也该告支付宝是什么什么是支付宝? 请详细介绍.连接cuteftp大飞资讯新闻资讯包括什么内容?
北京虚拟主机 域名注册中心 香港服务器租用99idc 工信部域名备案系统 新秒杀 优key 512m 远程登陆工具 网页背景图片 坐公交投2700元 gspeed 1g内存 免费美国空间 vip域名 如何安装服务器系统 如何注册阿里云邮箱 新世界服务器 什么是web服务器 摩尔庄园注册 supercache 更多