用递归写 赶鸭子题
题目:一个人赶着鸭子去每个村庄卖,每经过一个村子卖去所赶鸭子的一半又一只。这样他经过了七个村子后还剩两只鸭子,问他出发时共赶多少只鸭子?经过每个村子卖出多少只鸭子.
代码
#include"stdio.h"
#include"stdlib.h"
int duck(int n)
{
int sum;
if (n == 8)
{
sum = 2;
printf("经过第%d个村子时还剩%d只鸭子!\n",n,sum);
}
else
{
sum = (duck(n + 1) * 2)+2;
printf("经过第%d个村庄时还剩下%d只鸭子 卖了:%d只鸭子,\n", n, sum, (sum / 2 + 1));
}
return sum;
}
int main()
{
int n,sum=0;
duck(1);
system("pause");//用vs写的防止直接退出程序.
return 0;
}
还在学习阶段,递归还不怎么熟练,有不妥的地方多提意见.