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);
}
}



相关文章:

  • 2021-07-28
  • 2021-06-14
  • 2021-06-01
  • 2022-03-10
  • 2021-09-04
  • 2021-07-06
  • 2022-12-23
猜你喜欢
  • 2021-04-30
  • 2022-12-23
  • 2021-07-16
  • 2022-12-23
  • 2022-12-23
  • 2018-03-03
相关资源
相似解决方案