C语言 赶鸭子题 (用递归写)

用递归写 赶鸭子题

  • 题目:一个人赶着鸭子去每个村庄卖,每经过一个村子卖去所赶鸭子的==一半又一只==。这样他经过了==七个村子==后还剩两只鸭子,问他出发时共赶多少只鸭子?经过每个村子卖出多少只鸭子.
    • 代码

题目:一个人赶着鸭子去每个村庄卖,每经过一个村子卖去所赶鸭子的一半又一只。这样他经过了七个村子后还剩两只鸭子,问他出发时共赶多少只鸭子?经过每个村子卖出多少只鸭子.

代码

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

还在学习阶段,递归还不怎么熟练,有不妥的地方多提意见.

你可能感兴趣的:(C,递归法)