C语言:分糖果问题 10个小孩围成一圈分糖果

这个代码示例解决了一个关于10个小孩分糖果的问题,每次调整中,每个小孩将糖果减半并给右边的小孩,若数量为奇数则向老师要一块,直到所有小孩的糖果数相等。经过一系列的循环和判断,最终确定调整次数和每人糖果数。
摘要由CSDN通过智能技术生成

分糖果
10个小孩围成一圈分糖果,老师顺次分给每个人的糖数为12 2 8 22 16 4 10 6 14 20.
然后按下列规则进行调整,所有小孩同时把自己的糖果分一半给右边的小孩,糖块数变奇数的人,
再向老师补要一块,问经过多少次调整后,大家的糖块一样多,且每人多少块?

int main()
{
	int a[10] = { 12, 2, 8, 22, 16, 4, 10, 6, 14, 20 };
	int b[10] = { 0 };
    int w=1;
	int i,flag=0;
	int count = 0;
		while (w==1)
		{
			flag = 0;
			count++;
			for (i = 0; i < 10; i++)
			{
				b[i] = a[i] / 2;
			}
			for (i = 1; i < 10; i++)
			{
				a[i] = b[i] + b[i - 1];
			}
			a[0] = b[0] + b[9];
			for (i = 0; i < 10; i++)
			{
				if (a[i] % 2 != 0)
				{
					a[i]+=1;
				}
			}
			for (i = 0; i < 10; i++)
			{
				if (a[i]==a[i+1])
				{
					flag++;
				}
			}
			if (flag == 9)
				w = 0;
		}
	printf("经过%d次调整,且每个人%d块",count,a[0]);
	return 0;
}
在这里插入代码片
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值