小白提问-递归问题 return 1 是什么意思?

小白提问-递归问题 return 1 是什么意思?

如果n等于1就返回1return 1 这里面已经不包括函数本身,所以就停止递归了。所谓“递归”,通俗来讲就是函数里面再次调用函数本身,这就涉及到一个层次问题,就像坐电梯一样,比如一开始在一楼,递归调用一次,就等于到了二楼,然后每递归一次就上一层楼,到了某层楼(比如6楼)停止递归了,它并不是一下子就返回一楼的,而是要逐层楼下降的。下面举个例子,比方说number的值是5:一楼:result = factorial(5)二楼:return 5 * factorial(4)三楼:return 4 * factorial(3)四楼:return 3 * factorial(2)五楼:return 2 * factorial(1)六楼:return 1 //结束递归了返回五楼:return 2 * 1返回四楼:return 3 * 2返回三楼:return 4 * 6返回二楼:return 5 * 24返回一楼:result = 120其实从整个计算流程看,就相当于 1 * 2 * 3 * 4 * 5 = 120,也就是5的阶乘是120