坚果


私信TA

用户名:dotcpp0615334

访问量:4698

签 名:

等  级
排  名 118
经  验 7884
参赛次数 0
文章发表 43
年  龄 0
在职情况 学生
学  校 xx
专  业

  自我简介:

TA的其他文章

解题思路:

注意事项:注意是先分,后拿左边人的糖果!!如果理解为先拿左边人一半的糖果,后分是错的!!

参考代码:

#include<stdio.h>

int main()

{

     int n,a[100]={0};

     scanf("%d",&n);

     int i,t,sum1=0,sum2=0;

     for(i=0;i<n;i++)

     {

     scanf("%d",a+i);

     sum1+=a[i];//存之前数组的和,即一开始总的糖果数 

     }

     while(1)//这里按照题目的步骤来即可

     {

         for(i=0;i<n;i++)

         {

         a[i]/=2;//每位同学平分糖果后,给左边人,剩下来的一半 

         }

          t=a[0];//保留a[0],因为后面a[0]会发生变化

     for(i=0;i<n-1;i++)

     {

         a[i]+=a[i+1]; //平分之后在加上旁边一个人的 

     }

     a[n-1]+=t; //最后一个人的糖果等于自己的糖果+第一位同学糖果

     for(i=0;i<n;i++)

     {

         if(a[i]%2)//奇数 

         {

              a[i]+=1;//补糖果数

         }

     } 

     for(i=0;i<n-1;i++)

     {

         if(a[i]!=a[i+1])

         {

         break;

          }

     }//检测是否全相同 

       if(i==n-1)

       {

           break;

       }//全相同,跳出循环 

     }

     for(i=0;i<n;i++)

     {

         sum2+=a[i]; //后来的全部糖果数

     }

     printf("%d",sum2-sum1);

return 0;

 } 


 

0.0分

0 人评分

  评论区

  • «
  • »