题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2093

Problem Description
C++编程考试使用的实时提交系统,具有即时获得成绩排名的特点。它的功能是怎么实现的呢? 我们做好了题目的解答,提交之后,要么“AC”,要么错误,不管怎样错法,总是给你记上一笔,表明你曾经有过一次错误提交,因而当你一旦提交该题“AC”后,就要与你算一算帐了,总共该题错误提交了几回。虽然你在题数上,大步地跃上了一个台阶,但是在耗时上要摊上你共花去的时间。特别是,曾经有过的错误提交,每次都要摊上一定的单位时间分。这样一来,你在做出的题数上,可能领先别人很多,但是,在做出同样题数的人群中,你可能会在耗时上处于排名的劣势。 例如:某次考试一共8题(A,B,C,D,E,F,G,H),每个人做的题都在对应的题号下有个数量标记,负数表示该学生在该题上有过的错误提交次数,但到现在还没有AC,正数表示AC所耗的时间,如果正数a跟上一对括号,里面有个整数b,那就表示该学生提交该题AC了,耗去了时间a,同时,曾经错误提交了b次,因此对于下述输入数据:

若每次错误提交的罚分为20分,则其排名从高到低应该是这样的:
Josephus 5  376
John 4  284
Alice 4  352
Smith 3  167
Bob 2  325
Bush 0  0
Input
输入数据的第一行是考试题数n(1≤n≤12)以及单位罚分数m(10≤m≤20),每行数据描述一个学生的用户名(不多于10个字符的字串)以及对所有n道题的答题现状,其描述采用问题描述中的数量标记的格式,见上面的表格,提交次数总是小于100,AC所耗时间总是小于1000。
Output
将这些学生的考试现状,输出一个实时排名。实时排名显然先按AC题数的多少排,多的在前,再按时间分的多少排,的在,如果凑巧前两者都相等,则按名字的字典序排,小的在前。每个学生占一行,输出名字(10个字符宽),做出的题数(个字符宽,对齐)和时间分(个字符宽,对齐)。名字、题数和时间分相互之间有一个空格。
Sample Input
8 20
Smith     -1  -16   8   0   0   120   39  0
John     116   -2  11   0   0    82 55(1) 0
Josephus 72(3) 126 10  -3   0    47 21(2) -2
Bush       0   -1  -8   0   0     0    0  0
Alice     -2 67(2) 13  -1   0   133 79(1) -1
Bob        0   0 57(5)  0   0   168   -7   0
Sample Output
Josephus    5   376
John        4   284
Alice       4   352
Smith       3   167
Bob         2   325
Bush        0     0
解题思路:题目要求讲得很清楚,给出n个考试题目,单位罚时分为m,循环读入参赛人员的信息,没有限制参赛人数,但从AC时间小于1000,提交次数总是小于100来看,参赛人数即结构体数组长度开个(1W+1)就够了。输出规则是先按AC题目的数量从大到小排,再按AC总用时从小到大排,如果前两者相等,则按名字的字典序输出。另外用for循环读入每道题的情况,然后进行字符串处理,当遇到第一个字符是'-'或者该字符串是"0",则continue继续读取,不进行下步操作。思路很清晰,题目很基础!!!
AC代码:
 #include <bits/stdc++.h>
#define MAXN 10001
using namespace std;
struct node
{
char name[];//用户名
int ac;//ac的题目数量
int time;//总共花的时间
}stu[MAXN];//参加比赛的人数
bool cmp(node x,node y)//结构体排序规则
{
if(x.ac!=y.ac)return x.ac>y.ac;//先按ac的题量从大到小排
else if(x.time!=y.time)return x.time<y.time;//再按时间从小到大排
else return strcmp(x.name,y.name)<;//最后是按字典序排名
}
int main()
{
int n,m,t=;//n为考试题数,m为单位罚分数,t表示参赛人员的序号标记
char ch[];//输入每个题的得分情况
cin>>n>>m;
getchar(); //吃掉回车符
while(cin>>stu[t].name){//不断输入参赛人员的比赛信息
stu[t].ac=stu[t].time=;//同时初始化为0,下面进行计算
for(int i=;i<n;i++){ //循环读个n个题目的比赛情况
cin>>ch;
if((ch[]=='-')||(strcmp(ch,"")==))continue;//等于负数或为0,说明没有AC,直接进行下一个输入
stu[t].ac++;//AC了就先计数,接下来算AC这道题所用的时间
int j,tmp=;
for(j=;j<(int)strlen(ch)&&ch[j]!='(';j++)
tmp=tmp*+ch[j]-'';//先计算左括号旁边的数字
stu[t].time+=tmp;//先加解题所用的时间
tmp=;
if(j<(int)strlen(ch)){
for(int k=j+;k<(int)strlen(ch)-;k++) //计算括号内的数
tmp=tmp*+ch[k]-'';
}
stu[t].time+=tmp*m;//加上(之前错误提交次数乘上罚时总用时)
}
t++;//计数参赛人数
}
sort(stu,stu+t,cmp); //按规则排序
for(int i=;i<t;i++) // 输出排名信息
printf("%-10s %2d %4d\n",stu[i].name,stu[i].ac,stu[i].time);//按格式输出
return ;
}

题解报告:hdu 2093 考试排名的更多相关文章

  1. HDU——2093考试排名(string类及其函数的运用以及istringstream)

    考试排名 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submi ...

  2. HDU 2093 考试排名 模拟题

    解题报告: 题目描述:写一个程序给一个编程考试C++实时提交系统排名,给你的数据是题目的总数,每次错误提交罚的时间分,每位用户的姓名,然后是输入用户每题的完成情况,有一下几种情况,第一,输入只有一个正 ...

  3. HDOJ(HDU) 2093 考试排名(Arrays.sort排序、类的应用)

    Problem Description C++编程考试使用的实时提交系统,具有即时获得成绩排名的特点.它的功能是怎么实现的呢? 我们做好了题目的解答,提交之后,要么"AC",要么错 ...

  4. hdu 2093 成绩排名

    思路: 没啥思路,就是定义结构体,跟题目,走,当时没想到对那个括号的处理,后面看了题解,才知道用个getchar直接判断 算是一个值得思考的点. 代码: #include<bits/stdc++ ...

  5. 题解报告:hdu 1398 Square Coins(母函数或dp)

    Problem Description People in Silverland use square coins. Not only they have square shapes but also ...

  6. 题解报告:hdu 2069 Coin Change(暴力orDP)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2069 Problem Description Suppose there are 5 types of ...

  7. 题解报告:hdu 1028 Ignatius and the Princess III(母函数or计数DP)

    Problem Description "Well, it seems the first problem is too easy. I will let you know how fool ...

  8. 2015浙江财经大学ACM有奖周赛(一) 题解报告

    2015浙江财经大学ACM有奖周赛(一) 题解报告 命题:丽丽&&黑鸡 这是命题者原话. 题目涉及的知识面比较广泛,有深度优先搜索.广度优先搜索.数学题.几何题.贪心算法.枚举.二进制 ...

  9. cojs 强连通图计数1-2 题解报告

    OwO 题目含义都是一样的,只是数据范围扩大了 对于n<=7的问题,我们直接暴力搜索就可以了 对于n<=1000的问题,我们不难联想到<主旋律>这一道题 没错,只需要把方程改一 ...

随机推荐

  1. Idea 13 新建maven项目

    1.此时生成的maven项目没有web文件夹 file→New Project→Maven→Next→GID.AID (NewDemo)→Next→ProjectName(NewDemo)→Finis ...

  2. FancyCoverFlow

    https://github.com/davidschreiber/FancyCoverFlow

  3. java纯数字加密解密实例

    我们都知道,在用户加入信息时,一些比較敏感的信息,如身份证号,手机号,用户的登录password等信息,是不能直接明文存进数据库的.今天我们就以一个详细的样例来说明一下纯数字的java加密解密技术. ...

  4. 理解ValueStack的基本机制

    ValueStack基础:OGNL(Object Graphic Navigation Language) OGNL是Struts2中使用的一种表达式语言.它可以用于:   · 在JSP页面,使用标签 ...

  5. Struts2自定义过滤器的小例子-入门篇

    创建web项目    实现的效果! 用户点击页面不同的链接,后台调用不同的代码! 创建两个类实现共同的接口! public interface Action { String execute(); } ...

  6. mysql16---读写分离

    读写分离(负载平衡)(读写分离肯定要用到主从复制) 如果数据库压力很大,一台机器支撑不了,那么可以用mysql复制实现多台机器同步,将数据库的压力分散. 分表不能解决并发量大的问题. Sql语句发过来 ...

  7. javascript来实现详细时间提醒信息效果

    我们经常在社交网络上面看到很人性化的时间提示比如,你的朋友几分钟前更新了什么,你的朋友几天前更新了什么信息. 这些小tips比直接显示某年某月人性化很多.我们可以用不同的程序实现这种效果.中国音效网下 ...

  8. Expression Blend实例中文教程系列

    Expression Blend实例中文教程系列 本系列文章均转载:银光中国 时间:2010-04-09 09:20责任编辑:银光中国网 点击:次 Expression Blend实例中文教程系列由C ...

  9. CentOS 6.6实现永久修改DNS地址的方法

    本文实例讲述了CentOS 6.6实现永久修改DNS地址的方法. 百牛信息技术bainiu.ltd整理发布于博客园 分享给大家供大家参考,具体如下:1.配置ip地址文件 /etc/sysconfig/ ...

  10. 《The Unreasonable Effectiveness of Recurrent Neural Networks》阅读笔记

    李飞飞徒弟Karpathy的著名博文The Unreasonable Effectiveness of Recurrent Neural Networks阐述了RNN(LSTM)的各种magic之处, ...