js中的递归调用

functionfoo(i){if(i<0)return;console.log('begin:'+i);foo(i-1);console.log('end:'+i);}... function foo(i) {
if (i < 0)
return;
console.log('begin:' + i);
foo(i - 1);
console.log('end:' + i);
}
foo(3);

// 输出:

// begin:3
// begin:2
// begin:1
// begin:0
// end:0
// end:1
// end:2
// end:3
--------------------------------------------------------------------------------
上面的调用结果中,end是如何输出的?当i等于3时begin等于3,然后进入foo(i-1),程序就会回到第一步再次判断“i<0”,然后又会输出begin 我不明白 end是什么输出的?
展开
 我来答
三糖糖
2018-03-21 · TA获得超过373个赞
知道小有建树答主
回答量:390
采纳率:75%
帮助的人:117万
展开全部
其实,这就是一个简单的函数传参例子,我来给你简单讲一下:
foo(3);也就是往函数里面传入一个值等于3,也就是i=3
function foo(i) {
if (i < 0) //因为i=3了,这个时候3不是小于0,因此会跳到后面去执行,
return; //只有当i小于0时,才会输出结果,最终结果就等于0;
console.log('begin:' + i);
foo(i - 1);
console.log('end:' + i);
}
更多追问追答
追问
1,function foo(i) {
2,if (i < 0)
3,return;
4,console.log('begin:' + i);
5,foo(i - 1);
6,console.log('end:' + i);
7,}
8,foo(3);
当走到第五行是这个函数不是又从第二行开始判断吗?
追答
是的,i开始等于3,走到第5行减1,等于2,因此第二次会输出2,以此类推,当i=0时,才会最终结束整个判断过程
说话凭良心3q
2018-03-21 · TA获得超过123个赞
知道小有建树答主
回答量:235
采纳率:78%
帮助的人:73.2万
展开全部
其实你对递归的方法理解的有误了,以为执行了foo(i-1)就跳出了递归,其实只是跳出了递推,整个foo()并没有跳出,因为没有return;
递归故名思议就是递推和回归,递推是从外向内执行,bengin从3开始输出;当i=0时就不再递推,开始执行回归,回归是从内层往外层执行,end从0输出
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式