xiaocaiji


私信TA

用户名:biansecond

访问量:2387

签 名:

天道酬勤

等  级
排  名 15360
经  验 843
参赛次数 0
文章发表 7
年  龄 21
在职情况 学生
学  校 山东交通学院
专  业 物理+计算机

  自我简介:

解题思路:用一个数组存储各个学生手中糖果的初始数量 用for循环对每个同学手中的糖果进行自身减半同时加上右边同学手中糖果的一半。

fun()函数是用来判断数组中的元素是否完全相等

注意事项:在计算最后一个同学的糖果时要事先保留好第一个同学的糖果数量
参考代码:

#include<iostream>

using namespace std;

int a[100];

int n;

int fun(int *a)

{

    int flag=1;

    int res=a[0];

    for(int i=1;i<n;i++)

    {

    if(res!=a[i])return 0;

    }

    return flag;

}

int main()

{

    cin>>n;

    int count=0;

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

    {

    cin>>a[i];

    }

    while(fun(a)==0)

    {

    int start=a[0];

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

    {

    if(i==n-1)a[i]=a[i]/2+start/2;

    else a[i]=a[i]/2+a[i+1]/2;

    }

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

    {

    if(a[i]%2==1)

    {

    count++;

    a[i]+=1;

    }

    }

    }

    cout<<count;

    return 0;

}


 

0.0分

0 人评分

  评论区

  • «
  • »