1056 Mice and Rice(25分)

题目翻译:

模拟一个分组淘汰赛的过程,最终为每个选手确定排名。通过多轮比赛,在每一轮中将选手分组,每组选择一个得分最高的选手晋级到下一轮,并给其他选手分配排名,直到最终决出冠军。最终输出每个选手的排名。

题解思路:

模拟即可

代码:

#include<bits/stdc++.h>
using namespace std;
int P, G;//程序员数量,小组容量

int main()
{
	cin >> P >> G;
	vector<int> score(P),players(P),rank(P);
	for (int i = 0;i < P;i++) cin >> score[i];
	for (int i = 0;i < P;i++) cin >> players[i];
	int num = P;//当前玩家总数
	while (num > 1){
		vector<int> nextturn;//下一轮的人
		for (int i = 0;i < num;i += G){
			int jinji = i;//先假设每组的第一个人晋级,便于后续比较
			for (int j = i + 1;j < i + G && j < num;j++)
				if (score[players[jinji]] < score[players[j]]) jinji = j;
			nextturn.push_back(players[jinji]);
			for (int j = i;j < i + G && j < num;j++)
				if (j != jinji) rank[players[j]] = num / G + (num % G ? 1 : 0) + 1;
		}
		players = nextturn;
		num = num / G + (num % G ? 1 : 0);
	}
	rank[players[0]] = 1;
	for (int i = 0;i < rank.size();i++){
		if (i) cout << " ";
		cout << rank[i];
	}
}

坑点:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值