java递归和c语言递归的区别,浅谈递归函数(斐波那契数列的递归与非递归C语言实现及阶乘递归函数的实现)...

菲波那锲数的C语言实现;

1, 1,2,3,5,8,13,21,34,55,89… 斐波那契数列web

递归函数本质即调用自身;

看代码;递归实现斐波那契数列;

#include

int main()

{

int n=0;

scanf("%d",&n)

int fib(int n); // 声明斐波那契数列;

if(n<=2)

return 1;

else

return fib(n-1)+fib(n-2); // 根据斐波那契数列算法可得;

返回声明 n ;

}

{

int main()

int ret=0; // 声明最终的返回值 ret;

int n=0;

scanf("%d",&n); // ret=fib(n); 最终值返回;

ret=fib(n);

printf("%d",ret);

return 0;

}

非递归的:

#include

int main()

{

int n=0;

int fib(int n);

if (n<=2)

return 1;

else

{

int a=1; // a初始化1;

int b=1; //b初始化1 ;

int c=0;

for(i=2;i<=n;i++)

{

c=a+b; // c=a+b;

a=b; // 斐波那契数列后面的值依次向前进行加;b的值赋给a;

b=c;} // c的值赋给b 不断依次赋值再加

}

printf("\n");

return c;

}

递归的使用有两大条件:限制条件(跳出);无限接近条件;

阶乘的递归实现:算法

#include

int main()

{

int x=0;

printf("please enter a interger:");

scanf("%d",&x);

int fac(int x);

if(i<=1)

return 0;

else

return fac(n-1)*fac(n-2);

}

{

int main()

int ret=0;

int x=0;

scanf("%d",x);

ret=fac(n);

printf("%d",ret);

return 0;

}

阶乘的 非递归程序:

#include

#include

int main()

{

int i=0;

int ret=0;

printf("请输入数字:\n");

scanf("%d",&num);

if(i==0|| i=1)

{ return 1; }

if(i>1)

{

ret=i*(i-1);

return ret;

}

system ("pause");

return 0;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值