1957: 排名次
1.描述
在我们参加的acm各种竞赛中,并列排名方式是经常遇到的。 例如有5名选手的成绩分别为80,60,60,20,50分,则80分的选手为第一名,60分的两名选手均为第二名,50分的选手为第四名,20分的选手为第五名。 请写一个程序,计算一个选手的名次(分数高的选手排前面)。
输入
多组实例测试
第一行为一个整数N(1<=N<=1000000),表示参赛的选手数
第二行为N个整数,表示每位选手的成绩,第三行为一个整数m,表示要查询名次的选手的成绩。
输入0表示结束
输出
每组数据输出一个整数,表示该选手的名次。
样例输入
5
80 60 60 20 50
60
6
70 70 60 100 80 80
80
0
2.代码
#include<stdio.h>
#include<string.h>
#include<math.h>
int a[1000001];
int main()
{
int n;
while(scanf("%d",&n),n!=0)
{
int x,i,j,t,y=1;
for(i=0; i<n; i++)
{
scanf("%d",&a[i]);
}
scanf("%d",&x);
for(i=0; i<n; i++)
{
if(a[i]>x)
{
y++;
}
}
printf("%d\n",y);
}
return 0;
}
博客围绕ACM竞赛中选手名次计算展开,介绍了并列排名方式,如成绩为80、60、60、20、50分的选手排名情况。给出了计算选手名次的程序输入输出要求,包括多组实例测试、参赛选手数、成绩及要查询名次的选手成绩等,还提及代码部分。
1404

被折叠的 条评论
为什么被折叠?



