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. 我的周记8——"因为相信,所以看见"

    我没想明白过哪一种生活对幸福的定义更恰当,只是回顾我们走过的路,都是好春光,都像梦一场 JAVA学习视频 https://edu.aliyun.com/promotion/26?utm_content ...

  2. docke通信之Linux 网络命名空间

    一.前言 namespace(命名空间)和cgroup是软件容器化(想想Docker)趋势中的两个主要内核技术.简单来说,cgroup是一种对进程进行统一的资源监控和限制,它控制着你可以使用多少系统资 ...

  3. service的yaml说明

    apiVersion: v1 kind: Service metadata: name: nginx-service labels: app: nginx spec: ports: - port: 8 ...

  4. php 使用 wangeditor3 图片上传

    就在最近,公司让我写一个后台,其中用到了富文本编辑器.自从这个富文本的出现 我就慢慢的进入了一个坑,起初不知道用什么编辑器好,看了好多好多,最后选择了.这个 wangeditor3.个人认为这个富文本 ...

  5. c#ADO.NET 执行带参数及有返回数据

    直接上代码,这个过程中有个数据SqlDataReader转为 DataTable的过程,当中为什么这样,是应为我直接绑定DataSource的时候没有数据,网人家说直接绑定但是没效果,我就转换了一下. ...

  6. delegate里的Invoke和BeginInvoke

    Invoke和BeginInvoke都是调用委托实体的方法,前者是同步调用,即它运行在主线程上,当Invode处理时间长时,会出现阻塞的情况,而BeginInvod是异步操作,它会从新开启一个线程,所 ...

  7. 兼容 .NET Core3.0, Natasha 框架实现 隔离域与热编译操作

    关于 Natasha    动态构建已经成为了封装者们的家常便饭,从现有的开发趋势来看,普通反射性能之低,会迫使开发者转向EMIT/表达式树等构建方式,但是无论是EMIT还是表达式树,都会依赖于反射的 ...

  8. 转:Windows系统环境下安装dlib

    原文链接 因为今天安装Face Recognition,需要先按照 dlib .需要在windows环境下做一些图片处理,所以需要在pycharm中配置环境,而其中需要的主要是dlib的安装: 下面说 ...

  9. php 获取文件下的所有文件。php 获取文件下的所有子文件。php 递归获取文件下的所有文件。封装好的方法

    //php 获取文件下的所有文件.php 获取文件下的所有子文件.php 递归获取文件下的所有文件.直接上封装好的php代码 <?php //文件路径 $dir = dirname(__FILE ...

  10. ArrayList与LinkedList

    ArrayList与Linkedlist的增删改查问题以及集合选择问题 线程:安全:Vector 不安全:ArrayList,LinkedList 增删多:LinkedList 查询多:ArrayLi ...