题目1431:蓝桥杯2014年第五届真题-分糖果

//循环队列问题

#include<iostream>

#include<vector>

using namespace std;

int main() {

int n;

cin >> n;

vector<int> candies(n);

// 输入初始糖果数

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

cin >> candies[i];

}

int teacherGiven = 0; // 老师补发的糖果总数

while(true) {

// 检查是否所有小朋友糖果数相同

bool allSame = true;

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

if(candies[i] != candies[0]) {

allSame = false;

break;

}

}

if(allSame) break;

// 第一阶段:分糖(需要临时保存)

vector<int> temp = candies;

// 每个小朋友分一半给左手边的孩子

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

int give = temp[i] / 2; // 要给出的糖果数

// 给左边的小朋友(注意循环)

int left = (i - 1 + n) % n;//循环关键

candies[left] += give;

candies[i] -= give;

}

// 第二阶段:老师补糖

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

if(candies[i] % 2 != 0) { // 如果是奇数

candies[i]++; // 补1个糖果

teacherGiven++; // 计数增加

}

}

}

cout << teacherGiven << endl;

return 0;

}

相关推荐
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.2 小时前
Haproxy负载均衡算法全解析
算法
wanderist.2 小时前
蓝桥杯中的日期问题
c++·蓝桥杯
永远都不秃头的程序员(互关)4 小时前
【决策树深度探索(四)】揭秘“混乱”:香农熵与信息纯度的量化之旅
算法·决策树·机器学习
永远都不秃头的程序员(互关)4 小时前
【决策树深度探索(三)】树的骨架:节点、分支与叶子,构建你的第一个分类器!
算法·决策树·机器学习
Σίσυφος19004 小时前
OpenCV - SVM算法
人工智能·opencv·算法
清酒难咽10 小时前
算法案例之递归
c++·经验分享·算法
让我上个超影吧10 小时前
【力扣26&80】删除有序数组中的重复项
算法·leetcode
z203483152010 小时前
C++对象布局
开发语言·c++
张张努力变强11 小时前
C++ Date日期类的设计与实现全解析
java·开发语言·c++·算法