scala的伪递归

函数在伪递归时可以调用它自己,伪递归不一定是递归调用

比如100 * 99 * 98 * 97 * * * 1

用伪递归的话就不用开太多的栈,比如 100 * 99的结果会存到栈里,再乘98时,再用上一步的结果

去乘98,会得到一个结果,把第二次乘的结果存到栈里,把100 * 98的结果释放掉,以下同理,

一直乘到最后,会得到最后的对象是最终乘出来的结果,每乘一次会释放上一步的结果,

所以伪递归不会占用太多的空间

posted @ 2021-11-17 23:22  瘦多一点  阅读(61)  评论(0编辑  收藏  举报