题目描述
老师组织一群孩子围成一个圈进行游戏,游戏结束后老师会根据每个孩子的表现进行评分并给予糖果奖励。
每个孩子只能看见与自己相邻的 2 个孩子(左边的和右边的)的情况,只会关心相邻的且比自己评分低的同学的糖果数(如果相邻 2 个孩子的评分相等,则不关心)。为保证公平,相邻的孩子中,评分高的孩子必须获得更多的糖果(如果左右相邻 2 个孩子的评分相等,则不关心,即分最少的糖果1 个)。同时,为鼓励孩子的积极性,每个孩子至少都能拿到 1 个糖果。
现在需要你帮助老师来分发糖果,问怎么分配才能使要准备的糖果数最少?计算出需要的最少糖果数。
输入
输入有二行,第一行一个正整数n表示孩子的个数。
第二行n个非负整数,相邻的数用空格隔开,分别表示孩子的表现评分。
输出
一个整数,表示最少需要准备的糖果数。
样例输入 Copy
【样例1】 3 1 2 0 【样例2】 4 2 3 3 3
样例输出 Copy
【样例1】 6 【样例2】 6
样例输出 Copy
【样例1】 6 【样例2】 6
找到最低分的那个人,让他的糖果数为1,然后再去判断他的右边的人的糖果数,如郭当前的糖果无法满足要求,就从当前的人的糖果开始,往回改
#include#include #include #include using namespace std; struct node{ int le,v,ri; }; vector cc; int ca[100005]={0}; int n,t=0,it,M=1000,m; int main(){ cin>>n; while (t++ >m; if(m cc[cc[j].ri].v&&ca[j]<=ca[cc[j].ri]){ ca[j]=ca[cc[j].ri]+1; } else { // cout<<" lll "< cc[cc[i].le].v){ ca[i]=ca[cc[i].le]+1; } else if(cc[i].v==cc[cc[i].le].v){ ca[i]=1; } else if(cc[i].v cc[cc[j].ri].v&&ca[j]<=ca[cc[j].ri]){ ca[j]=ca[cc[j].ri]+1; } else { // cout<<" lll "< 欢迎分享,转载请注明来源:内存溢出
评论列表(0条)