当前位置: 首页 > news >正文

关于一种计算递归次数题的思路

代码如下
要求计算最后输出的count的结果

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
int count = 0;
int fib(int a)
{count++;if (a == 0)return 1;else if (a == 1)return 2;elsereturn fib(a - 1) + fib(a - 2);
}
int main()
{fib(10);printf("%d", count);
}

当遇到此类检索递归调用次数的题目,我们可以以由简到繁的思路来解决

我们看到,上面的例题直接进行计算是很复杂的,如果从输入的数字10开始解决,一步一步按顺序罗列,最终要计算的数字几乎是天文的(不过也没那么夸张,真硬算也能算)

此时对于这类递归,我们可以倒着来,从简单的数入手

我们可以先计算fib(0),此时显然,主函数的打印结果为1,因为count++;语句只被执行了一次

我们再来计算fib(1),同样count++;语句只被执行了一次

再看fib(2),当输入的值为2,我们执行else后的语句fib(1) + fib(0),神奇的事情发生了,我们发现计算fib(2)的结果正好是fib(1)fib(0)的结果之和再加上1(这里1是首次进入函数时count++的值,也就是执行fib(2)的这次)

那么计算方式就很明确了,我们只需要依次计算下去,很容易就能得到fib(10)输出的count的值

比如fib(3)的count的值就等于fib(2)fib(1)的count值再加一,fib(4)的count的值等于fib(3)的count的值加fib(2)的count的值再加1,以此类推,最后得到结果为177

http://www.jsqmd.com/news/34639/

相关文章:

  • 前端框架深度解析:Vue 从入门到实战,掌握渐进式开发核心 - 实践
  • CF2162G
  • 题解:lo6878 生不逢时
  • 【UEGamePlay】- 3C篇(三) : 角色 (二)
  • stapter WP笔记
  • 【51单片机】【protues仿真】基于51单片机全自动洗衣机系统 - 教程
  • 定金单专题
  • 练习上传
  • uniapp修改原生导航栏样式、加图标、加文字、加点击事件 - 详解
  • CITP——更适合约束接口的CRTP变式 - CLimber
  • 函数的可变参数传参
  • P12366 [蓝桥杯 2022 省 Python B] 数位排序
  • 重组蛋白表达技术|HEK293细胞蛋白表达|高效重组蛋白生产服务
  • CJI8运行查询没有数据
  • Para 集训
  • RK3576在智能工程机械中的应用|三屏八摄AI视觉解决方案
  • 贪心,排序,二分,分治
  • python01
  • AI Compass前沿速览:Cursor 2.0、Firefly Image5、Agent HQ 、LongCat-Video、Kimi-k2 Thinking
  • 25.11.7联考题解
  • 浅谈dp中的最优化、计数问题
  • CF715B
  • [NOIP 2001 提高组] 一元三次方程求解
  • EPnP算法学习随笔
  • 毒盘未转存仅支持在线观看30s
  • P14322 「ALFR Round 11」E 空崎ヒナ 小结
  • AI元人文:理论自省与客观评估
  • [Element Plus 组件库的官方 API 参考文档] 的部分内容的解释
  • ZK笔记
  • 完整教程:《以 Trae 为桥:高效集成豆包 1.6 API 的实践与思考》