解题思路:
注意事项:
参考代码:
/* 3
2 2 4
1 1 2
1+1=2 1+2=3 2+1=3
2 4 4
1 2 2
2 2 2*/
#include<stdio.h>
int main(){
int a[105];
int n,sum=0;//标记补发的糖果
scanf("%d",&n);
int i,z;
int tag;
for(i=0;i<n;i++){//输入每个小孩的糖果数量
scanf("%d",&a[i]);
}
while(1){//开始循环
tag=0;//作为标记
if(a[0]%2==0){
z=a[0]/2;// Z 为第一个小孩减半后的糖果数量
}
else{
z=(a[0]+1)/2;
}
for(i=0;i<n;i++){
if(a[i]%2==1){//从头至尾 糖果数若是双数则直接减半 单数就加一在减半 记入补发的数目
a[i]+=1;
sum++;// 单数的情况 将补发的糖果数 记入
}
a[i]/=2;
if(a[i]!=z){
tag=1;//若是 有小孩的糖果数不等于第一个小孩的数目 则标记为 1
}
}
if(tag==0){//顺序查完所有 若是标记为 0 则说明所有人的糖果数均相等 结束程序 并打印补发的数目
printf("%d\n",sum);
break;
}
for(i=0;i<n-1;i++){//若 数目仍不均等 则每一个人的数目加上后面人的 (所有人的数目均已减半)
a[i]+=a[i+1];
}
a[n-1]+=z;//最后一个的数目加上第一个的数目
}
return 0;
}
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复