The ranklist of PAT is generated from the status list, which shows the scores of the submissions. This time you are supposed to generate the ranklist for PAT.

Input Specification:

Each input file contains one test case. For each case, the first line contains 3 positive integers, N(≤10​^4​​), the total number of users, K (≤5), the total number of problems, and M (≤10^5), the total number of submissions. It is then assumed that the user id's are 5-digit numbers from 00001 to N, and the problem id's are from 1 to K. The next line contains K positive integers p[i] (i=1, ..., K), where p[i] corresponds to the full mark of the i-th problem. Then M lines follow, each gives the information of a submission in the following format:

user_id problem_id partial_score_obtained

where partial_score_obtained is either − if the submission cannot even pass the compiler, or is an integer in the range [0, p[problem_id]]. All the numbers in a line are separated by a space.

Output Specification:

For each test case, you are supposed to output the ranklist in the following format:

rank user_id total_score s[1] ... s[K]

where rank is calculated according to the total_score, and all the users with the same total_score obtain the same rank; and s[i] is the partial score obtained for the i-th problem. If a user has never submitted a solution for a problem, then "-" must be printed at the corresponding position. If a user has submitted several solutions to solve one problem, then the highest score will be counted.

The ranklist must be printed in non-decreasing order of the ranks. For those who have the same rank, users must be sorted in nonincreasing order according to the number of perfectly solved problems. And if there is still a tie, then they must be printed in increasing order of their id's. For those who has never submitted any solution that can pass the compiler, or has never submitted any solution, they must NOT be shown on the ranklist. It is guaranteed that at least one user can be shown on the ranklist.

Sample Input:

7 4 20
20 25 25 30
00002 2 12
00007 4 17
00005 1 19
00007 2 25
00005 1 20
00002 2 2
00005 1 15
00001 1 18
00004 3 25
00002 2 25
00005 3 22
00006 4 -1
00001 2 18
00002 1 20
00004 1 15
00002 4 18
00001 3 4
00001 4 2
00005 2 -1
00004 2 0

Sample Output:

1 00002 63 20 25 - 18
2 00005 42 20 0 22 -
2 00007 42 - 25 - 17
2 00001 42 18 18 4 2
5 00004 40 15 0 25 -
//用户id 00001 - N
//问题id 1 - K
//p[i] 第i个问题的满分 //M行 用户id 问题id 得分(-1提交未能通过编译,[0-p[i]分]) /*
输入格式
rank user_id total_score s[1]...s[k]
rank 名次,总分相同,名词相同 按满分数量和 按id非递减方式排序
s[1]...s[k] 提交问题获得的分数,如果没有提交输出- ,提交数次取最高分
没有提交任何解决方案或者任何解决方案都没有通过编译的就不进行排序了
*/ #include<cstdio>
#include<algorithm>
using namespace std;
const int maxn = ; struct Student
{
int id;
int score[]; //总分以及1-k(<=5)问题得分 总分初始化为0,各题目初始化-1
int num_full; //满分题目数,初始化0
bool isSummit;
}stu[maxn]; void init(int n,int k);
bool cmp(Student a, Student b); int main()
{
int n,k,m;
int full_mark[];
scanf("%d%d%d", &n, &k, &m); init(n,k); for (int i = ; i <= k; i++)
{
scanf("%d",&full_mark[i]);
} int id, num_ques, nGrade;
for (int i = ; i < m; i++)
{
scanf("%d %d %d",&id, &num_ques, &nGrade); stu[id].id = id;
if (nGrade == - && stu[id].score[num_ques] == -)
{
stu[id].score[num_ques] = ;
}
if (nGrade != -)
{
stu[id].isSummit = true;
}
if (stu[id].score[num_ques] < nGrade) //分数大于已保存的,更替
{ stu[id].score[num_ques] = nGrade;
if (nGrade == full_mark[num_ques]) //满分时,满分数量+1
{
stu[id].num_full++;
}
}
} for (int i = ; i <= n; i++)
{
for (int j = ; j <= k; j++)
{
if (stu[i].score[j] != -)
{
stu[i].score[] += stu[i].score[j];
}
}
} sort(stu+, stu+n+, cmp); int rank = ;
for (int i = ; i <= n; i++)
{
if (!stu[i].isSummit)
{
break;
}
if (i != && stu[i].score[] != stu[i-].score[])
{
rank = i;
}
printf("%d %05d %d ", rank, stu[i].id, stu[i].score[]);
for (int j = ; j <= k; j++)
{
if (stu[i].score[j] == -)
{
printf("-");
}
else
{
printf("%d",stu[i].score[j]);
} if (j < k)
{
printf(" ");
}
else
{
printf("\n");
}
}
} return ;
} void init(int n,int k)
{
for (int i = ; i <= n; i++)
{
stu[i].score[] = ;
stu[i].num_full = ;
stu[i].isSummit = false;
for (int j = ; j <= k; j++)
{
stu[i].score[j] = -;
}
}
} bool cmp(Student a, Student b)
{
if (a.isSummit != b.isSummit)
{
return a.isSummit > b.isSummit;
}
else if (a.score[] != b.score[])
{
return a.score[] > b.score[];
}
else if (a.num_full != b.num_full)
{
return a.num_full > b.num_full;
}
else
{
return a.id < b.id;
}
}

10-排序5 PAT Judge (25 分)的更多相关文章

  1. PTA 10-排序5 PAT Judge (25分)

    题目地址 https://pta.patest.cn/pta/test/16/exam/4/question/677 5-15 PAT Judge   (25分) The ranklist of PA ...

  2. PAT 甲级 1075 PAT Judge (25分)(较简单,注意细节)

    1075 PAT Judge (25分)   The ranklist of PAT is generated from the status list, which shows the scores ...

  3. PATA1075 PAT Judge (25 分)

    The ranklist of PAT is generated from the status list, which shows the scores of the submissions. Th ...

  4. A1075 PAT Judge (25 分)

    The ranklist of PAT is generated from the status list, which shows the scores of the submissions. Th ...

  5. PTA 5-15 PAT Judge (25分)

    /* * 1.主要就用了个sort对结构体的三级排序 */ #include "iostream" #include "algorithm" using nam ...

  6. 【PAT甲级】1075 PAT Judge (25 分)

    题意: 输入三个正整数N,K,M(N<=10000,K<=5,M<=100000),接着输入一行K个正整数表示该题满分,接着输入M行数据,每行包括学生的ID(五位整数1~N),题号和 ...

  7. A1075 PAT Judge (25)(25 分)

    A1075 PAT Judge (25)(25 分) The ranklist of PAT is generated from the status list, which shows the sc ...

  8. PAT甲级:1025 PAT Ranking (25分)

    PAT甲级:1025 PAT Ranking (25分) 题干 Programming Ability Test (PAT) is organized by the College of Comput ...

  9. 1025 PAT Ranking (25分)

    1025 PAT Ranking (25分) 1. 题目 2. 思路 设置结构体, 先对每一个local排序,再整合后排序 3. 注意点 整体排序时注意如果分数相同的情况下还要按照编号排序 4. 代码 ...

随机推荐

  1. Docker 创建 Redis 容器

    Docker 创建 Redis 容器 # 配置文件映射: # -v /root/redis/redis.conf:/etc/redis/redis.conf # 数据目录映射: # -v /root/ ...

  2. WebStrom安装Markdown插件

    安装步骤 File→Settings→Plugins→关键字搜索markdown→选择Markdown Navigator→点击Install→出现下载弹窗,等待下载完毕→重启Webstrom 效果预 ...

  3. 【题解】Paid Roads [SP3953] [Poj3411]

    [题解]Paid Roads [SP3953] [Poj3411] 传送门:\(\text{Paid}\) \(\text{Roads}\) \(\text{[SP3953]}\) \(\text{[ ...

  4. 大型情感剧集Selenium:6_selenium中的免密登陆与cookie操作【华为云技术分享】

    网站登录 现在各大平台在反爬虫功能上,可谓花样繁多.总结下来按照破解成功率排名,最高的是滑动解锁.其次是验证码数字.之后是一次点击对应的汉字,最后是想12306之前那种反人类的让你说那些是奶糖吧,哈哈 ...

  5. 2019-11-29-WPF-非客户区的触摸和鼠标点击响应

    原文:2019-11-29-WPF-非客户区的触摸和鼠标点击响应 title author date CreateTime categories WPF 非客户区的触摸和鼠标点击响应 lindexi ...

  6. c#对象深复制demo

    public class Person : ICloneable { public string Name; object ICloneable.Clone() { return this.Clone ...

  7. mysql删除重复数据(通过多个字段分组,删除某一字段为空的数据)

    DELETE FROM t_questions WHERE Id in ( SELECT Id FROM ( SELECT Id FROM `t_questions` WHERE (Name,Ques ...

  8. 2019年,Golang开始吊打Java性能了!!!

    最近要同事debug性能,不经意间发现现在Golang性能开始吊打Java了!!!感觉Go发展神速!! 之前Go和Java基本是平手,甚至还有较大差距,请见https://www.cnblogs.co ...

  9. 2.Shell脚本中的set指令,比如set -x 和 set -e

    set参数介绍 set指令能设置所使用shell的执行方式,可依照不同的需求来做设置 -a 标示已修改的变量,以供输出至环境变量. -b 使被中止的后台程序立刻回报执行状态. -C 转向所产生的文件无 ...

  10. 设计模式之(十三)外观模式(Facade)

    外观模式思想 历史上牛人中成功逆袭,实现人生辉煌的人很多,这群人最耀眼的无疑是明太祖朱元璋,从一个放牛讨饭的最低层小屌丝逆袭到人类权力顶峰开国皇帝,确实是我等膜拜的对象.在发不断的发展过程中,其实就在 ...