【算法】js递归与循环的效率

638 阅读1分钟

递归算法:

  优点:代码简洁、清晰,并且容易验证正确性。

  缺点:它的运行需要较多次数的函数调用,如果调用层数比较深,需要增加额外的堆栈处理,比如参数传递需要压栈等操作,会对执行效率有一定影响。但是,对于某些问题,如果不使用递归,那将是极端难看的代码。

循环算法:

  优点:速度快,结构简单。

  缺点:并不能解决所有的问题。有的问题适合使用递归而不是循环。如果使用循环并不困难的话,最好使用循环。

递归算法和循环算法总结

  1. 一般递归调用可以处理的算法,也通过循环去解决常需要额外的低效处理。

  2. 现在的编译器在优化后,对于多次调用的函数处理会有非常好的效率优化,效率未必低于循环。

递归的实现是通过调用函数本身,函数调用的时候,每次调用时要做地址保存,参数传递等,这是通过一个递归工作栈实现的。具体是每次调用函数本身要保存的内容包括:局部变量、形参、调用函数地址、返回值。那么,如果递归调用N次,就要分配N局部变量、N形参、N调用函数地址、N返回值。

当递归的次数太大的时候内存不足便会出现堆栈溢出的状况了

循环和递归根据具体情况使用