C和指针之函数之实现阶乘和斐波那契数(递归和非递归)

举报
chenyu 发表于 2021/07/27 01:27:16 2021/07/27
【摘要】 1、问题 实现阶乘和斐波那契数(递归和非递归)   2、代码实现 #include <stdio.h> int num = 0;//递归实现斐波那契数// n <=2, f(n) = 1, n > 2 f(n) = f(n - 1) + f();long fibonacci(int n){ //计算fibonacci...

1、问题

实现阶乘和斐波那契数(递归和非递归)

 


2、代码实现


   
  1. #include <stdio.h>
  2. int num = 0;
  3. //递归实现斐波那契数
  4. // n <=2, f(n) = 1, n > 2 f(n) = f(n - 1) + f();
  5. long fibonacci(int n)
  6. {
  7. //计算fibonacci(3)计算了多少次
  8. if (n == 3)
  9. num++;
  10. if (n <= 2)
  11. {
  12. printf("num is %d\n", num);
  13. return 1;
  14. }
  15. return fibonacci(n - 1) + fibonacci(n - 2);
  16. }
  17. //非递归实现斐波那契数
  18. long fibonacci1(int n)
  19. {
  20. long result = 1, pre_result = 1, next_pre_result;
  21. while (n > 2)
  22. {
  23. n -= 1;
  24. next_pre_result = pre_result;
  25. pre_result = result;
  26. result = pre_result + next_pre_result;
  27. }
  28. return result;
  29. }
  30. //递归实现n的阶乘
  31. //n <= 1, f(n) = 1, n > 1 f(n) = n * f(n - 1);
  32. long factorial(int n)
  33. {
  34. if (n == 1)
  35. return 1;
  36. return n * factorial(n - 1);
  37. }

文章来源: chenyu.blog.csdn.net,作者:chen.yu,版权归原作者所有,如需转载,请联系作者。

原文链接:chenyu.blog.csdn.net/article/details/78463624

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。