原题链接:蓝桥杯2014年第五届真题-分糖果
1.解题思路
第一步:看一下所有的数是不是相等,如果是,flag=1,否则,flag=0
第二步:全体减半
第三步:所有的数都加上左边的数,相当于把左边数的一半给了这个数
第四步:判断奇偶,如果是奇数,则这个数和ans都加一
2.注意事项
注意while语句上是!flag
3.参考代码
#include<iostream> using namespace std; const int MAX=101; int kid[MAX],n,i,temp,ans=0; int main(){ bool flag; cin>>n; for(i=0;i<n;i++) cin>>kid[i]; while(!flag){ flag=true; for(i=1;i<n;i++) if(kid[0]!=kid[i]) flag=false; for(i=0;i<n;i++) kid[i]=kid[i]/2; temp=kid[n-1]; for(i=n-1;i>0;i--) kid[i]+=kid[i-1]; kid[0]+=temp; for(i=0;i<n;i++) if(kid[i]%2!=0){ kid[i]++; ans++; } } cout<<ans<<endl; return 0; }
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复