【问题描述】
在选美大奖赛的半决赛现场,有n名选手(2<n<100)参加比赛。比赛结束时,要在现场按照选手的出场顺序宣布最后名次,获得相同分数的选手具有相同的名次,名次连续编号,不用考虑同名次的选手人数。如:
选手数量: 7
选手得分: 5,3,4,7,3,5,6
宣布名次: 3,5,4,1,5,3,2
请编程帮助大奖赛组委会完成半决赛的评分排名工作。
【输入形式】
选手数量:7
选手得分:5 3 4 7 3 5 6
【输出形式】
选手的排名:3 5 4 1 5 3 2
【样例输入】
7 5 3 4 7 3 5 6
【样例输出】
3 5 4 1 5 3 2
【样例说明】
本题的关键在于如何处理同分数的选手排名问题
【问题描述】
在选美大奖赛的半决赛现场,有n名选手(2<n<100)参加比赛。比赛结束时,要在现场按照选手的出场顺序宣布最后名次,获得相同分数的选手具有相同的名次,名次连续编号,不用考虑同名次的选手人数。如:
选手数量: 7
选手得分: 5,3,4,7,3,5,6
宣布名次: 3,5,4,1,5,3,2
请编程帮助大奖赛组委会完成半决赛的评分排名工作。
【输入形式】
选手数量:7
选手得分:5 3 4 7 3 5 6
【输出形式】
选手的排名:3 5 4 1 5 3 2
【样例输入】
7 5 3 4 7 3 5 6
【样例输出】
3 5 4 1 5 3 2
【样例说明】
本题的关键在于如何处理同分数的选手排名问题
#include<iostream>
#include<algorithm>
using namespace std;
struct student {
int cheng;
int num;
};
int main() {
int n;
cin >> n;
student* pai = new student[n];
for (int i = 0; i < n; i++) {
cin >> pai[i].cheng;
}//cin is true
int* nnum = new int[n];
for (int i = 0; i < n; i++) {
nnum[i] = pai[i].cheng;
}//so this is true
int temp = 0;
int numtempp = 0;
int numtemp1 = 0;
sort(nnum, nnum + n, greater<int>());//it was in this process turn out wrong sort(nnum, nnum + 10)
for (int i = 0; i < n; i++) {
for (int ii = 0; ii < n; ii++) {
if (nnum[ii] == nnum[i]) {
if (numtemp1 == 1) {
nnum[ii] = -999;
}
else {
numtemp1++;
}
}
}
numtemp1 = 0;
}
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
if (pai[j].cheng == nnum[i]) {
pai[j].num = temp+1;//in this turn the output is 忽略
//the solution is to trand arrt `s size make the last is -99
//no a anthoe number!
numtempp++;
//如果将每个数只限定为1次那么每次就只是会在同一个数中间出现了
// 因为不然的话会被后面的数字覆盖上去
//原来是因为找不到的一趟也会加的情况
}
}
if (numtempp== 0) {
temp--;
}
numtempp = 0;
temp++;
}
for (int i = 0; i < n; i++) {
cout << pai[i].num << " ";
}
return 0;
}