杭电OJ2093 C语言

  • 题目
  • 整体思路
  • 代码

题目

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个字符宽),做出的题数(2个字符宽,右对齐)和时间分(4个字符宽,右对齐)。名字、题数和时间分相互之间有一个空格。

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

整体思路

  • 先按行读入数据,一次性全部读入再解析,因此这里用到了一个3维数组input[1000][12][10](由于C不支持字符串,所以用3维,正常2维就行),第一维代表记录的是哪个人的信息(Josephus…),第二维代表哪门科目(A,B…),第三维就是具体的数据即字符串(字符数组保存);
  • 读入完毕后再对数据解析,这里定义了结构体Student用来保存姓名、答对题目数量、时间分。通过对字符串处理来解析出每位同学的这三种信息。
  • 解析完毕后,对存储数组采取冒泡排序的方法。
  • 排序后输出

代码

#include <stdio.h>
#include <string.h>
#include <stdlib.h>struct Student{char name[11];int acNum;int timeScore;
};int main() {int m, n, i, j, k, l, studentNum = 0;scanf("%d%d", &n, &m);//读取科目数以及惩罚分数struct Student student[1000], student_tmp;char input[1000][12][10], time_tmp[5], wrong_tmp[4];while (scanf("%s", student[studentNum].name) != EOF) {//读取所有数据,姓名直接放入结构体内,其余装入input数组,后面再解析for (i = 0; i < n; ++i)scanf("%s", input[studentNum][i]);studentNum++;}for (i = 0; i < studentNum; ++i) {//处理input数组,获取每个同学的答对题数和时间分for (j = 0; j < n; ++j) {if (strcmp(input[i][j], "0") == 0 || input[i][j][0] == '-')//记录位0或为负数不处理continue;else {student[i].acNum++;//不为0和负数即一定做出来了,因此+1if (strchr(input[i][j], '(') == NULL)//判断是否作答多次student[i].timeScore += atoi(input[i][j]);else {//作答多次需综合处理for (k = 0; input[i][j][k] != '('; ++k)//提取回答正确答题时间time_tmp[k] = input[i][j][k];time_tmp[k++] = '\0';for (l = 0; input[i][j][k] != ')'; ++k)//提取回答错误次数wrong_tmp[l++] = input[i][j][k];wrong_tmp[l++] = '\0';student[i].timeScore += atoi(time_tmp) + atoi(wrong_tmp) * m;//综合计算时间分}}}}for (j = 0; j < studentNum; ++j) {//冒泡排序for (i = 0; i < studentNum - j - 1; i++) {if ((student[i].acNum < student[i + 1].acNum) ||//三个比较条件((student[i].acNum == student[i + 1].acNum) && (student[i].timeScore > student[i + 1].timeScore)) ||((student[i].acNum == student[i + 1].acNum) && (student[i].timeScore == student[i + 1].timeScore) &&(strcmp(student[i].name, student[i + 1].name) > 0))) {student_tmp = student[i];student[i] = student[i + 1];student[i + 1] = student_tmp;}}}for (i = 0; i < studentNum; ++i) {//格式化输出printf("%-10s %2d %4d\n", student[i].name, student[i].acNum, student[i].timeScore);}}

杭电OJ2093 C语言相关推荐

  1. c语言编程杭电1008,C语言程序设计_杭州电子科技大学cyy1_3

    <C语言程序设计_杭州电子科技大学cyy1_3>由会员分享,可在线阅读,更多相关<C语言程序设计_杭州电子科技大学cyy1_3(8页珍藏版)>请在人人文库网上搜索. 1.1,可 ...

  2. 杭电--1009 C语言实现

    思路:要用有限的猫粮得到最多的javabean,则在房间中得到的javabean比例应尽可能的大.用一个结构体,保存每个房间中的javabean和猫粮比例和房间号,然后将结构体按比例排序,则从比例最大 ...

  3. 杭电OJ第11页2075~2079算法题(C语言)

    目录 2075.A|B? 2076.夹角有多大 2077.汉诺塔IV 2078.复习时间 2079.选课时间 2075.A|B? Problem Description 正整数A是否能被正整数B整除, ...

  4. 杭电acm的第1000题c语言解法

    首先我选择的是c语言的解法,开始是输入如下的答案: #include "stdio.h" int main(void) { long long a,b; scanf("% ...

  5. 杭电oj1620题c语言答案,杭电oj部分水题 c语言源代码.doc

    杭电oj部分水题 c语言源代码 殿剐忱酪短祭幂曝沈脸蛀蓑挞姻扶宠秤蓄幌榆矾巨旷于渍弯史影得熄孟椒菊葫彦籍蛛绊趣庙捣载睹答赊索添垛蝎伙生瞎回悟辅篇狱辗歧病氯急迸怜煽跋屋凡逻甲确烧迟卞姻郸被康少辊蒂刽厂礁 ...

  6. 杭电1042c语言循环,HDU杭电1052 Tian Ji - The Horse Racing答题报告

    HDU杭电1052 Tian Ji -- The Horse Racing解题报告 本人第一次写博客,希望各位大神多多指导与包涵,不足的地方还请指出,新手在此谢过啦!!! 题目描述: Time Lim ...

  7. 杭电OJ第11页2035~2039算法题(C语言)

    目录 2035.人见人爱A^B 2036.改革春风吹满地 2037.今年暑假不AC 2038.Message 2039.三角形 2035.人见人爱A^B Problem Description 求A^ ...

  8. 杭电OJ第11页2085~2089算法题(C语言)

    目录 2085.核反应堆 2086.A1 = ? 2087.剪花布条 2088.Box of Bricks 2089.不要62 2085.核反应堆 Problem Description 某核反应堆有 ...

  9. 杭电OJ第11页2065~2069算法题(C语言)

    目录 2065."红色病毒"问题 2066.一个人的旅行 2067.小兔的棋盘 2068.RPG的错排 2069.Coin Change 2065."红色病毒" ...

最新文章

  1. Google和网易有道合作开课了
  2. 基于jQuery+ashx+.net实现三级栏目联动操作
  3. 关于android开发环境的创建
  4. 解决sublime text3 v3.1.1,Build3176中的汉字形状扭曲问题
  5. 斯坦福2019强化学习课程完结,讲义、PPT、视频已提供下载
  6. EC++学习笔记(四) 设计与声明
  7. JavaScript引用类型之Array数组的concat()和push()方法的区别
  8. python除数为0报错_python 错误捕获机制分析
  9. linux根文件系统制作
  10. 一个离线的简单的 JSON 格式化编辑器
  11. 关于《windows游戏编程大师技巧》的源代码
  12. 如何利用TFTP服务器上传文件到真机交换机?可使用SecureCRT和3CDaemon工具
  13. 宝塔实测-电商ERP进销存系统源码
  14. 类对象模型实验:类数据成员大小
  15. C - Copy (hdu)
  16. 鸿蒙石之鉴老猴死了怎么办,智取芭蕉扇那个剧情选分支1过不了怎么办
  17. java石头剪刀布思路_石头剪刀布Java实现
  18. Acrobat右键菜单失踪了?Regsvr32无用?
  19. 每天可以一看的哲理句子
  20. 图新地球系列教程-标绘编辑:(项目实战技巧,做出好看实用的标绘)

热门文章

  1. 64位eclipse免安装版下载
  2. MySQL 错误:2003 - Can‘t connect to MySQL server on ‘localhost‘ (10061 “Unknown error“)
  3. (python)班级身高排序
  4. Laravel框架中,Post请求返回419或者500,因为默认有csrf验证
  5. django返回excel文件给前端下载
  6. Python:请输入一段信息,并计算这串消息的信源熵
  7. Faster-rcnn模型下载
  8. 为测试赋能,腾讯WeTest探索手游AI自动化测试之路
  9. Java市场饱和了?为什么都这么说...
  10. 3dmax 管子动画_3ds MAX 7.0 PF Source粒子详解之水管中流淌的水-动画与插件-3DMAX教程网,3DMAX下载...