[C/C++]Fibonacci numbers

  

int fib(int n){
if (n ==1|| n ==2) {
return1;
}
return fib(n-1) + fib(n-2);
}

  

复制代码
void fib_(int n, int* fibn, int* fibn_1){
if (n ==2|| n ==1) {
*fibn =1;
*fibn_1 =1;
}
else{
fib_(n
-1,fibn,fibn_1);
*fibn =*fibn +*fibn_1;
*fibn_1 =*fibn -*fibn_1;
}
};

int fib2(int n ){
int fibn;
int fib_1;
fib_(n,
&fibn,&fib_1);
return fibn;
}
复制代码

 

 

复制代码
int fib_tail_recur_(int n,int fib_n, int fib_n_minus1)
{
if(n == 3)
{
return fib_n + fib_n_minus1;
}
else
{
return fib_tail_recur_(n-1,fib_n + fib_n_minus1, fib_n);
}
}

int fib_tail_recur(int n)
{
if (n < 3){
return 1;
}else
{
return fib_tail_recur_(n,1,1);
}
}
复制代码



posted @   嗷嗷  阅读(845)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述
点击右上角即可分享
微信分享提示