信息学奥赛一本通(1176:谁考了第k名)——qsort 函数
1176:誰考了第k名
時間限制: 1000 ms ??? ??? 內存限制: 65536 KB
提交數: 32951 ??? 通過數: 14262
【題目描述】
在一次考試中,每個學生的成績都不相同,現知道了每個學生的學號和成績,求考第k名學生的學號和成績。
【輸入】
第一行有兩個整數,分別是學生的人數n(1≤n≤100)n(1≤n≤100),和求第k名學生的k(1≤k≤n)k(1≤k≤n)。
其后有nn行數據,每行包括一個學號(整數)和一個成績(浮點數),中間用一個空格分隔。
【輸出】
輸出第kk名學生的學號和成績,中間用空格分隔。(注:請用%g%g輸出成績)
【輸入樣例】
5 3 90788001 67.8 90788002 90.3 90788003 61 90788004 68.4 90788005 73.9【輸出樣例】
90788004 68.4【參考代碼】
#include <stdio.h>
#include <stdlib.h>
#define N 110
struct In
{
?? ?int id;
?? ?double score;
}stu[N];
int cmp( const void *a ,const void *b)
{
?? ?struct In *aa = (struct In *)a;
? ??? ?struct In *bb = (struct In *)b;
? ??? ?return aa->score < bb->score ? 1 : -1; ? //從大到小排序?
}
int main()
{
? ? struct In t;
? ? int i,j,n,k;
? ? scanf("%d%d",&n,&k);
? ? for(i=0;i<n;i++)
? ? ?? ?scanf("%d %lf",&stu[i].id,&stu[i].score);
? ??
? ? qsort(stu,n,sizeof(stu[0]),cmp);
? ??
?? ?printf("%d %lg\n",stu[k-1].id,stu[k-1].score);
? ? return 0;
}
http://ybt.ssoier.cn:8088/problem_show.php?pid=1176
?
總結
以上是生活随笔為你收集整理的信息学奥赛一本通(1176:谁考了第k名)——qsort 函数的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 信息学奥赛一本通 1027:输出浮点数
- 下一篇: 信息学奥赛一本通 1096:数字统计 |