P1058 选择题

转跳点:

1058 选择题 (20分)

批改多选题是比较麻烦的事情,本题就请你写个程序帮助老师批改多选题,并且指出哪道题错的人最多。

输入格式:

输入在第一行给出两个正整数 N(≤ 1000)和 M(≤ 100),分别是学生人数和多选题的个数。随后 M 行,每行顺次给出一道题的满分值(不超过 5 的正整数)、选项个数(不少于 2 且不超过 5 的正整数)、正确选项个数(不超过选项个数的正整数)、所有正确选项。注意每题的选项从小写英文字母 a 开始顺次排列。各项间以 1 个空格分隔。最后 N 行,每行给出一个学生的答题情况,其每题答案格式为 (选中的选项个数 选项1 ……),按题目顺序给出。注意:题目保证学生的答题情况是合法的,即不存在选中的选项数超过实际选项数的情况。

输出格式:

按照输入的顺序给出每个学生的得分,每个分数占一行。注意判题时只有选择全部正确才能得到该题的分数。最后一行输出错得最多的题目的错误次数和编号(题目按照输入的顺序从 1 开始编号)。如果有并列,则按编号递增顺序输出。数字间用空格分隔,行首尾不得有多余空格。如果所有题目都没有人错,则在最后一行输出 Too simple

输入样例:

  1. 3 4
  2. 3 4 2 a c
  3. 2 5 1 b
  4. 5 3 2 b c
  5. 1 5 4 a b d e
  6. (2 a c) (2 b d) (2 a c) (3 a b e)
  7. (2 a c) (1 b) (2 a b) (4 a b d e)
  8. (2 b d) (1 e) (2 b c) (4 a b c d)

输出样例:

  1. 3
  2. 6
  3. 5
  4. 2 2 3 4

这道题稍微复杂一些,但吧PAT乙里面的题只需要进行拆解,拆出来的每一部分都是很简单的。

这道题可以使用结构数组存储每一道题的分数、选项数、正确选项数、正确选项和学生答错数量。一千个coder就会有一千种存储方法,我存储方式上取了个巧(又飘了( ̄▽ ̄)”)

我没有对选项进个数和正确答案个数进行存储,我采用了位字段的方式对正确答案进行存储,因为答案选项最多只有5个,用整型的5个位的0 1存储刚好合适,例如 a b d e,那么这个量就是二进制00011011(从低向高存储)

代码实现如下:

  1. int AnsRecord()
  2. {
  3. char ch;
  4. int AnsQun, Ans = 0;
  5. scanf("%d", &AnsQun);
  6. for (int i = 0; i < AnsQun; i++)
  7. {
  8. while (' ' == (ch = getchar()))
  9. ;
  10. Ans |= 1 << (ch - 'a');
  11. }
  12. return Ans;
  13. }

这样直接比较整型的大小就知道答案是否一致,并且综合了选项数、正确选项数、正确选项三项信息,节约的空间,也节省了时间。(其实就是脑子抽了 ╰( ̄ω ̄o))

AC代码:

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3.  
  4. typedef struct QunData
  5. {
  6. int mark;
  7. int wrong; //错误个数
  8. int Ans; //位字段方式存储
  9. } Qun;
  10.  
  11. int AnsRecord();
  12.  
  13. int main(void)
  14. {
  15. int qunstionQun, studentQun, max = 0;
  16.  
  17. scanf("%d %d", &studentQun, &qunstionQun);
  18.  
  19. Qun Quntion[qunstionQun];
  20.  
  21. for (int i = 0; i < qunstionQun; i++)
  22. {
  23. scanf("%d %d", &Quntion[i].mark, &Quntion[i].wrong);
  24. Quntion[i].wrong = 0;
  25. Quntion[i].Ans = AnsRecord();
  26. }
  27.  
  28. for (int i = 0; i < studentQun; i++)
  29. {
  30. int score = 0;
  31. for (int j = 0; j < qunstionQun; j++)
  32. {
  33. while (getchar() != '(')
  34. ;
  35. if (Quntion[j].Ans == AnsRecord())
  36. {
  37. score += Quntion[j].mark;
  38. }
  39. else if (++Quntion[j].wrong > max)
  40. {
  41. max = Quntion[j].wrong;
  42. }
  43. while (getchar() != ')')
  44. ;
  45. }
  46. printf("%d\n", score);
  47. }
  48.  
  49. if (0 == max)
  50. {
  51. printf("Too simple");
  52. }
  53. else
  54. {
  55. printf("%d", max);
  56. for (int i = 0; i < qunstionQun; i++)
  57. {
  58. if (Quntion[i].wrong == max)
  59. {
  60. printf(" %d", i + 1);
  61. }
  62. }
  63. }
  64.  
  65. return 0;
  66. }
  67.  
  68. //读入正确答案
  69. int AnsRecord()
  70. {
  71. char ch;
  72. int AnsQun, Ans = 0;
  73. scanf("%d", &AnsQun);
  74. for (int i = 0; i < AnsQun; i++)
  75. {
  76. while (' ' == (ch = getchar()))
  77. ;
  78. Ans |= 1 << (ch - 'a');
  79. }
  80. return Ans;
  81. }

PTA不易,诸君共勉!

P1058 选择题的更多相关文章

  1. Hibernate选择题总结

    Hibernate选择题总结 1.在Hibernate中,以下关于主键生成器说法错误的是( ). A.increment可以用于类型为long.short或byte的主键 B.identity用于如S ...

  2. 选择题(codevs 2919)

    2919 选择题  时间限制: 1 s  空间限制: 16000 KB  题目等级 : 黄金 Gold 题解  查看运行结果     题目描述 Description 某同学考试,在N*M的答题卡上写 ...

  3. Servlet、JSP选择题(2)

    Java EE软件工程师认证考试 试题库-选择题 一.    选择题(包括单选和双选) 1.B 编写一个Filter,需要(  ) A. 继承Filter 类 B. 实现Filter 接口 C. 继承 ...

  4. Servlet、JSP选择题

    Java EE软件工程师认证考试 试题库-选择题   一.    选择题(包括单选和双选) 1.A 对于B/S架构的工作流程,以下说法正确的是(   )(选择一项) A. 浏览器接受用户的输入--&g ...

  5. JavaScript、Jquery选择题

    尚学堂Java EE软件工程师认证考试 试题库-选择题     一.    选择题(包括单选和双选) 1.B 在JavaScript中,以下变量命名非法的是(   )(选择一项) A. numb_1 ...

  6. HTML、CSS选择题

    Java EE软件工程师认证考试 试题库-选择题   一.    选择题(包括单选和双选) 1.D 以下(    )是HTML常用的块状标签(选择一项) A. <span> B. < ...

  7. opencv 手写选择题阅卷 (二)字符识别

    opencv 手写选择题阅卷 (二)字符识别 选择题基本上只需要识别ABCD和空五个内容,理论上应该识别率比较高的,识别代码参考了网上搜索的代码,因为参考的网址比较多,现在也弄不清是参考何处的代码了, ...

  8. opencv 手写选择题阅卷 (四)Android端 手机应用开发

    opencv 手写选择题阅卷 (四)Android 手机应用开发 在PC端把代码调通以后开始开发Android 手机应用,因为主要功能代码为C++代码,所以需要通过NDK编译,JAVA通过JNI方式调 ...

  9. opencv 手写选择题阅卷 (三)训练分类器

    opencv 手写选择题阅卷 (三)训练分类器 1,分类器选择:SVM 本来一开始用的KNN分类器,但这个分类器目前没有实现保存训练数据的功能,所以选择了SVN分类器; 2,样本图像的预处理和特征提取 ...

随机推荐

  1. js实现配置菜品规格时,向后台传一个json格式字符串

    由于本公司做的是订餐平台,那么在上传菜品时,需要配置菜品规格,比如份量(大中小),味道(猛辣,中辣,微辣) 由于这些数据,在表的设计时 没有保存到菜品表,那么在点击保存菜品数据时,配置规格这块数据,我 ...

  2. java编译问题之Description Resource Path Location Type Java compiler level does not match the version of

    project 编译问题,需要三处的jdk版本要保持一致,才能编译通过. 1.在项目上右键properties->project Facets->修改右侧的version  保持一致 2. ...

  3. 20199317 myod实验

    myod实验 实验内容: 1 复习c文件处理内容 2 编写myod.c 用myod XXX实现Linux下od -tx -tc XXX的功能 3 main与其他分开,制作静态库和动态库 4 编写Mak ...

  4. 【快学Docker】Docker镜像相关操作

    前言 镜像是Docker的三大核心概念之一(另外两个分别是:容器和仓库). Docker运行容器前需要本地存在镜像,如果本地不存在镜像,Docker则会尝试从远端仓库拉去镜像.镜像是Docker一大核 ...

  5. Legal High

    不让任何人承担责任,不想看的东西就回避, 但是,如果想夺回值得夸耀的生存方式,就必须看那些不愿意看的现实,必须带着身负重伤的觉悟前进,这才叫做战斗. 有怨言的话去坟墓里说,钱不是全部,钱就是你们向对手 ...

  6. 【转】postgres数据库创建索引

    一.索引的类型: PostgreSQL提供了多 种索引类型:B-Tree.Hash.GiST和GIN,由于它们使用了不同的算法,因此每种索引类型都有其适合的查询类型,缺省时,CREATE INDEX命 ...

  7. swoole 消息队列

    <?php /** * 场景: * 监控订单表状态 队列通信 * 一个进程向队列发布消息 另外两个进程争抢 */ //设置主进程名 echo '主进程id:' . posix_getpid() ...

  8. Linux centosVMware xshell使用xftp传输文件、使用pure-ftpd搭建ftp服务

    一.xshell使用xftp传输文件 Ctrl+Alt+F 弹出 下载进入 填写任意名字,自己邮箱 进入邮箱点击网址就自动下载了 然后安装 二.使用pure-ftpd搭建ftp服务 yum insta ...

  9. error C2664: “FILE *fopen(const char *,const char *)”: 无法将参数 1 从“LPCTSTR”转换为“const char *”

    遇到这个问题,请打开本项目的Properties(属性)-------> Configuration Properties(配置属性)-------->General(常规)------- ...

  10. ImageMagick 将PDF转图片命令

    将 pdf 转一张图片 PS C:\Users\Microestc\desktop> magick convert -density -quality .pdf -append .jpeg ro ...