风好甜啊


私信TA

用户名:dotcpp0715987

访问量:59

签 名:

等  级
排  名 21768
经  验 667
参赛次数 0
文章发表 1
年  龄 0
在职情况 学生
学  校 忻州师范学院
专  业

  自我简介:

解题思路:

注意事项:

参考代码:

#include<stdio.h>
int main(){
	int n,i,f,b=0;//b为补发糖果个数,f为判断每个人是否相等的标志
	int stu[101];
	scanf("%d",&n);
	stu[0]=0;//缓冲区
	for(i=1;i<=n;i++){
		scanf("%d",&stu[i]);	
	}
	while(!f){
		stu[0]=stu[1]/2;//将第一个人糖果的一半存入缓存区
		for(i=1;i<n;i++){ //换糖果,这此循环并不能让最后一个人拿到糖果
			stu[i]=stu[i]/2+stu[i+1]/2;
		}
		stu[n]=stu[n]/2+stu[0];//需要重新给最后一个人的糖果进行赋值,最后一个人糖果的一半加上第一个人的一半
		for(i=1;i<=n;i++){
			if(stu[i]%2!=0){//判断糖果奇偶数
				stu[i]=stu[i]+1;
				b++;
			}
		}
		for(i=1;i<=n;i++){
			if(stu[i]==stu[1]){
				f=1;
			}else {
				f=0;
				break;
			}
		}
	}
	printf("%d",b);
	return 0;
	
}


 

0.0分

0 人评分

  评论区

  • «
  • »