10-排序5 PAT Judge (25 分)
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 分)的更多相关文章
- 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 ...
- PAT 甲级 1075 PAT Judge (25分)(较简单,注意细节)
1075 PAT Judge (25分) The ranklist of PAT is generated from the status list, which shows the scores ...
- PATA1075 PAT Judge (25 分)
The ranklist of PAT is generated from the status list, which shows the scores of the submissions. Th ...
- A1075 PAT Judge (25 分)
The ranklist of PAT is generated from the status list, which shows the scores of the submissions. Th ...
- PTA 5-15 PAT Judge (25分)
/* * 1.主要就用了个sort对结构体的三级排序 */ #include "iostream" #include "algorithm" using nam ...
- 【PAT甲级】1075 PAT Judge (25 分)
题意: 输入三个正整数N,K,M(N<=10000,K<=5,M<=100000),接着输入一行K个正整数表示该题满分,接着输入M行数据,每行包括学生的ID(五位整数1~N),题号和 ...
- A1075 PAT Judge (25)(25 分)
A1075 PAT Judge (25)(25 分) The ranklist of PAT is generated from the status list, which shows the sc ...
- PAT甲级:1025 PAT Ranking (25分)
PAT甲级:1025 PAT Ranking (25分) 题干 Programming Ability Test (PAT) is organized by the College of Comput ...
- 1025 PAT Ranking (25分)
1025 PAT Ranking (25分) 1. 题目 2. 思路 设置结构体, 先对每一个local排序,再整合后排序 3. 注意点 整体排序时注意如果分数相同的情况下还要按照编号排序 4. 代码 ...
随机推荐
- 阿里云ECS服务器CentOS7.2安装Python2.7.13
阿里云ECS服务器CentOS7.2安装Python2.7.13 yum中最新的也是Python 2.6.6,只能下载Python 2.7.9的源代码自己编译安装. 操作步骤如下: 检查CentOS7 ...
- day11——函数名的使用、f格式化、迭代器、递归
day11 函数名的第一类对象及使用 1.可以当作值被赋值给变量 def func(): print(1) print(func) a = func a() 2.当作元素存放在容器中 def func ...
- 利用开源项目 FFMpegSharp 实现音视频提取、转码、抓图等操作
开源项目地址:https://github.com/vladjerca/FFMpegSharp 首先需要在 web.config 或 app.config 中配置 <appSettings> ...
- 【CTS2019】氪金手游(动态规划)
[CTS2019]氪金手游(动态规划) 题面 LOJ 洛谷 题解 首先不难发现整个图构成的结构是一棵树,如果这个东西是一个外向树的话,那么我们在意的只有这棵子树内的顺序关系,子树外的关系与这棵子树之间 ...
- golang学习笔记----源码文件
GO源码文件
- golang学习笔记---string && strconv
1.字符串的组成?Golang的字符串都是由单个字节连接起来的,每个字节都是UTF8编码标识的Unicode文本.(不需要在考虑中文不兼容问题) 2.如何遍历字符串?先看一个例子: package m ...
- Python 绘图与可视化 matplotlib text 与transform
Text 为plots添加文本或者公式,反正就是添加文本了 参考链接:https://matplotlib.org/api/_as_gen/matplotlib.pyplot.text.html#ma ...
- 微信页面script标签添加crossorigin=“anonymous”导致页面加载失败
公司一个微信企业号项目,突然出现页面数据加载失败,页面报错信息如下 意思是前端向服务端发送跨域资源请求访问这个js文件,但是服务端并不同意,所以服务端拒绝访问这个地址. 后来发现将crossorigi ...
- 在centos下安装rar解压.rar压缩包
CentOS本身不自带rar环境,因此对于rar文件无法直接解压,需要先配置rar环境. 首先需要确定自己的系统是64位还是32位的,通过这个命令: [root@localhost]# uname - ...
- TinyMCE基础配置
选择器配置 插件配置 工具栏配置 菜单配置 皮肤配置 编辑区宽高配置 编辑区样式配置 隐藏状态栏 选择器配置 选择器就是CSS选择器,它告诉TinyMCE哪个元素是可编辑的. 示例: tinymce. ...