美文网首页C语言
C语言中的递归程序可以用非递归算法实现吗?

C语言中的递归程序可以用非递归算法实现吗?

作者: java云帆 | 来源:发表于2019-04-22 20:56 被阅读0次

C语言所有递归都可以用非递归算法实现,最典型的就是迭代法,有时比递归更容易理解。至于递归中的形式参数是自动变量,没明白楼主的意思,形参就是形参啊,形参变量也是变量,其内存分配在栈区,随着函数的结束,其内存也会被释放,形参的生命周期与函数生命周期相同哈(同生共死)

实现方法

#include

unsigned int Fibonacci(int n);

int main( void )

{

int i;

for(i = 1 ;i <= 20;i ++)

{

printf("%d ",Fibonacci(i));

}

return 0;

}

unsigned int Fibonacci(int n)

{

if( n == 1 || n == 2) // 递归结束的条件,求前两项

return 1;

else

return Fibonacci(n-1)+Fibonacci(n-2); // 如果是求其它项,先要求出它前面两项,然后做和。

}

以上便是小编对“C语言中的递归程序可以用非递归算法实现吗?”的大致介绍,希望能有所帮助!

其实做为一个开发者,有一个学习的氛围跟一个交流圈子特别重要这里我推荐一个C语言C++交流群692375453,不管你是小白还是大牛欢迎入驻,大家一起交流成长。

相关文章

  • C语言中的递归程序可以用非递归算法实现吗?

    C语言所有递归都可以用非递归算法实现,最典型的就是迭代法,有时比递归更容易理解。至于递归中的形式参数是自动变量,没...

  • 快速幂模板

    递归算法 非递归算法

  • 二分查找

    1.非顺序表查找最大值递归算法 2.顺序表的二分查找算法查找下标最小的特定元素x 递归实现 非递归实现

  • 二叉树的遍历(先序、中序、后序)

    树结构: 先序:递归:C++: 非递归:C++: 中序:递归:C++: 非递归:C++: 后序:递归:C++: 非...

  • java中常见的递归使用场景

    一、递归概述 程序调用自身的编程技巧称为递归.递归作为一种算法在程序设计语言中广泛应用。递归需具备的条件: 子问题...

  • 递归实例

    递归基本概念 程序调用自身的编程技巧称为递归( recursion)。递归做为一种算法在程序设计语言中广泛应用。 ...

  • Java算法之递归的简单应用

    递归基本概念 程序调用自身的编程技巧称为递归( recursion)。递归做为一种算法在程序设计语言中广泛应用。 ...

  • 二叉树的遍历实现递归与非递归

    本文实现了二叉树的深度遍历算法,分为递归与非递归 递归的实现非常简单,基本上没啥难度 非递归的实现需要根据遍历的顺...

  • 从斐波那契数列看递归与动态规划

    递归算法就是通过解决同一问题的一个或多个更小的实例来最终解决一个大问题的算法。为了在C语言中实现递归算法,常常使用...

  • 数据结构-树的遍历

    1. 先序遍历 递归实现 非递归实现 2. 中序遍历 递归实现 非递归实现 3. 后序遍历 递归实现 非递归实现 ...

网友评论

    本文标题:C语言中的递归程序可以用非递归算法实现吗?

    本文链接:https://www.haomeiwen.com/subject/vbgaiqtx.html