http://acm.hdu.edu.cn/showproblem.php?pid=1236

Problem Description
今天的上机考试虽然有实时的Ranklist,但上面的排名只是根据完成的题数排序,没有考虑 
每题的分值,所以并不是最后的排名。给定录取分数线,请你写程序找出最后通过分数线的 
考生,并将他们的成绩按降序打印。 
 
Input
测试输入包含若干场考试的信息。每场考试信息的第1行给出考生人数N ( 0 < N 
< 1000 )、考题数M ( 0 < M < = 10 )、分数线(正整数)G;第2行排序给出第1题至第M题的正整数分值;以下N行,每行给出一 
名考生的准考证号(长度不超过20的字符串)、该生解决的题目总数m、以及这m道题的题号 
(题目号由1到M)。 
当读入的考生人数为0时,输入结束,该场考试不予处理。 
 
Output
对每场考试,首先在第1行输出不低于分数线的考生人数n,随后n行按分数从高 
到低输出上线考生的考号与分数,其间用1空格分隔。若有多名考生分数相同,则按他们考 
号的升序输出。 
 
Sample Input
4 5 25
10 10 12 13 15
CS004 3 5 1 3
CS003 5 2 4 1 3 5
CS002 2 1 2
CS001 3 2 3 5
1 2 40
10 30
CS001 1 2
2 3 20
10 10 10
CS000000000000000001 0
CS000000000000000002 2 1 2
0
 
Sample Output
3
CS003 60
CS001 37
CS004 37
0
1
CS000000000000000002 20
 
题解:
字符串排序:1. 找到两个字符串的最长公共前缀 2. 比较公共前缀后面那个字符的大小即可
计算分数的和:

  1. for(int j=1; j<=s[i].m; j++)
  2. {
  3. int x;
  4. scanf("%d",&x);
  5. s[i].add+=q[x].score;
  6. }
 
代码:
  1. #include <bits/stdc++.h>
  2.  
  3. using namespace std;
  4.  
  5. const int maxn = 1e5+10;
  6. int N,M,G;
  7.  
  8. struct Students
  9. {
  10. char id[21];
  11. int m;
  12. int add;
  13. } s[maxn];
  14.  
  15. int Com(char s1[maxn],char s2[maxn])
  16. {
  17. int len1 = strlen(s1);
  18. int len2 = strlen(s2);
  19. int m = min(len1,len2);
  20. for(int i=0; i<m; i++)
  21. {
  22. if(s1[i]-s2[i]>0)
  23. return 1;
  24. else if(s1[i]-s2[i]==0)
  25. continue;
  26. else
  27. return -1;
  28. }
  29. if(len1==len2)
  30. return 0;
  31. else if(len1>len2)
  32. return 1;
  33. else
  34. return -1;
  35. }
  36.  
  37. struct Q
  38. {
  39. int score;
  40. int num;
  41. } q[maxn];
  42. void display()
  43. {
  44. int sum=0;
  45. for(int i=1; i<=N; i++)
  46. {
  47. if(s[i].add>=G)
  48. sum++;
  49. }
  50. printf("%d\n",sum);
  51. for(int i=1; i<=N; i++)
  52. {
  53. if(s[i].add>=G)
  54. printf("%s %d\n",s[i].id,s[i].add);
  55. }
  56. }
  57.  
  58. bool cmpScore( Students& a, Students& b)
  59. {
  60. if(a.add==b.add)
  61. return Com(a.id,b.id)<=0;
  62. else
  63. return a.add>b.add;
  64. }
  65.  
  66. int main()
  67. {
  68. while(~scanf("%d",&N))
  69. {
  70. if(N==0)
  71. break;
  72. scanf("%d%d",&M,&G);
  73. for(int i=1; i<=M; i++)
  74. {
  75. scanf("%d",&q[i].score);
  76. }
  77. for(int i=1; i<=N; i++)
  78. {
  79. s[i].add=0;
  80. scanf("%s%d",s[i].id,&s[i].m);
  81. for(int j=1; j<=s[i].m; j++)
  82. {
  83. int x;
  84. scanf("%d",&x);
  85. s[i].add+=q[x].score;
  86. }
  87. }
  88. int L=1,R=N;
  89. sort(s+L,s+R+1,cmpScore);
  90. display();
  91. }
  92. return 0;
  93. }

  

HDU 1236 排名(Microsoft_zzt)的更多相关文章

  1. 题解报告:hdu 1236 排名

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1236 Problem Description 今天的上机考试虽然有实时的Ranklist,但上面的排名 ...

  2. HDU 1236 排名(结构体+排序)

    今天的上机考试虽然有实时的Ranklist,但上面的排名只是根据完成的题数排序,没有考虑 每题的分值,所以并不是最后的排名.给定录取分数线,请你写程序找出最后通过分数线的 考生,并将他们的成绩按降序打 ...

  3. hdu 1236 排名(排序)

    题意:按成绩排序 思路:排序 #include<iostream> #include<stdio.h> #include<string.h> #include< ...

  4. hdu 1236 1.3.2排名

    排名 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submission ...

  5. HDOJ 1236 排名(练耐心题)

    Problem Description 今天的上机考试虽然有实时的Ranklist,但上面的排名只是根据完成的题数排序,没有考虑 每题的分值,所以并不是最后的排名.给定录取分数线,请你写程序找出最后通 ...

  6. HDU 1236

    水题~~但我做了很久: 题意:是中国人都懂了 思路:结构体排序: 以后要多用用重定义的排序手段,!!!!!多用!!多用!!多用!! #include<iostream> #include& ...

  7. 题解 HDU 3698 Let the light guide us Dp + 线段树优化

    http://acm.hdu.edu.cn/showproblem.php?pid=3698 Let the light guide us Time Limit: 5000/2000 MS (Java ...

  8. 1236 hdu排名

    Problem Description 今天的上机考试虽然有实时的Ranklist,但上面的排名只是根据完成的题数排序,没有考虑 每题的分值,所以并不是最后的排名.给定录取分数线,请你写程序找出最后通 ...

  9. HDU 1285 确定比赛排名 (数组实现 )

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1285 确定比赛名次 Time Limit: 2000/1000 MS (Java/Others)    ...

随机推荐

  1. 寒假集训——搜索 D - Cubes for Masha

    #include <stdio.h> #include <stdlib.h> #include <iostream> #include <string.h&g ...

  2. 难点--均方误差(MSE)和均方根误差(RMSE)和平均绝对误差(MAE)

    MSE: Mean Squared Error 均方误差是指参数估计值与参数真值之差平方的期望值; MSE可以评价数据的变化程度,MSE的值越小,说明预测模型描述实验数据具有更好的精确度. MSE=1 ...

  3. 转://oracle 11gR2 oracle restart 单机使用asm存储 主机名发生更改处理过程

    oracle 11gR2 oracle restart 单机使用asm存储 主机名发生更改并且主机重启后处理过程: 以下为解决方案: 1. Remove Oracle Restart configur ...

  4. 遇到的web请求错误码集合与解释

    302 临时移动.与301类似.但资源只是临时被移动.客户端应继续使用原有URI

  5. patch函数的解释2

    patch 创建补片图形对象 句法: patch(X,Y,C) patch(X,Y,Z,C) patch(FV) patch(...'PropertyName',propertyvalue...) p ...

  6. JVM解释器和编译器

    首先看一个命令 [root@insure ~]# java -version java version "1.8.0_191" Java(TM) SE Runtime Enviro ...

  7. python 数据结构 队列(queue)

    如需转发,请注明出处:小婷儿的python https://www.cnblogs.com/xxtalhr/p/10293817.html 欢迎关注小婷儿的博客: 有问题请在博客下留言或加作者微信:t ...

  8. Centos 7 KVM安装win10

    KVM架构: KVM 是基于虚拟化扩展(Intel VT 或者 AMD-V)的 X86 硬件的开源的 Linux 原生的全虚拟化解决方案.KVM 中,虚拟机被实现为常规的 Linux 进程,由标准 L ...

  9. 查看Orcale数据里的表是否有变化

    由于我们公司一个数据库两个应用在使用,导致一个应用修改了数据库,另一个应用用的缓存而不知道有更新还是原来的结果.原来的处理方式是采用session缓存的方式,用户登出了就清空缓存,这样只需要重新登录一 ...

  10. ftp 传输数据:命令链路连接方法是一样的,而数据链路的建立方法就完全不同

    0.FTP协议有两种工作方式:PORT方式和PASV方式,中文意思为主动式和被动式. PORT(主动)连接过程是:客户端向服务器的FTP端口(默认是21)发送连接请 求,服务器接受连接,建立一条命令链 ...