1073. 多选题常见计分法

2024-01-19 14:32
文章标签 常见 计分 多选题 1073

本文主要是介绍1073. 多选题常见计分法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、题目

批改多选题是比较麻烦的事情,有很多不同的计分方法。有一种最常见的计分方法是:如果考生选择了部分正确选项,并且没有选择任何错误选项,则得到50%分数;如果考生选择了任何一个错误的选项,则不能得分。本题就请你写个程序帮助老师批改多选题,并且指出哪道题的哪个选项错的人最多。

输入格式:

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

输出格式:

按照输入的顺序给出每个学生的得分,每个分数占一行,输出小数点后1位。最后输出错得最多的题目选项的信息,格式为:“错误次数 题目编号(题目按照输入的顺序从1开始编号)-选项号”。如果有并列,则每行一个选项,按题目编号递增顺序输出;再并列则按选项号递增顺序输出。行首尾不得有多余空格。如果所有题目都没有人错,则在最后一行输出“Too simple”。

输入样例1:
3 4
3 4 2 a c
2 5 1 b
5 3 2 b c
1 5 4 a b d e
(2 a c) (3 b d e) (2 a c) (3 a b e)
(2 a c) (1 b) (2 a b) (4 a b d e)
(2 b d) (1 e) (1 c) (4 a b c d)
输出样例1:
3.5
6.0
2.5
2 2-e
2 3-a
2 3-b
输入样例2:
2 2
3 4 2 a c
2 5 1 b
(2 a c) (1 b)
(2 a c) (1 b)
输出样例2:
5.0
5.0
Too simple

二、个人理解

本题主要考察字符串处理及数值计算。


关键算法(实现题目错误选项统计):

  • 定义一个总的统计所有题目的错误选项个数的二维数组,先全部初始化为0;
  • 然后在一个学生答一个题目时,定义一个临时数组(长度为5,因为选项最多为5个),初始化,然后将数组[参考答案]+=2,数组[学生答案]+=1;
  • 最后比较其数组的值,若只含有3,则全部正确;若含有1,则为错误;若不含有1且含有2,则部分正确。

C++:

#include <iostream>
#include <string>
#include <cstdio>
using namespace std;
int main()
{int n, m;cin >> n >> m;string question[m], t;getline(cin, t);for (int i = 0; i < m; i++) {getline(cin, question[i]);}string student[n];for (int i = 0; i < n; i++) {getline(cin, student[i]);}float score[n];int total[m][5];//统计所有题目的错误选项个数//初始化for (int i = 0; i < n; i++) {score[i] = 0.0;}for (int i = 0; i < m; i++) {for (int j = 0; j < 5; j++) {total[i][j] = 0;}}//for (int i = 0; i < n; i++) {string temp = student[i];int tag = 0;for (int j = 0; j < temp.length(); j++) {if (temp[j] >= '1' && temp[j] <= '5') {int solve[5];for (int k = 0; k < 5; k++) {solve[k] = 0;}//参考答案则加2for (int k = 6; k < question[tag].length(); k = k + 2) {solve[question[tag][k] - 'a'] += 2;}//学生答案则加1for (int k = j + 2; k <= (temp[j] - '0') * 2 + j; k = k + 2) {solve[temp[k] - 'a']++;}int error = 0, warning = 0;for (int k = 0; k < 5; k++) {if (solve[k] == 1) {total[tag][k]++;error = 1;//错误} else if (solve[k] == 2) {total[tag][k]++;warning = 1; //部分正确}}//部分正确if (error == 0 && warning == 1) {score[i] += (float)(question[tag][0] - '0') / 2.0;} else if (error == 0 && warning == 0) {//完全正确score[i] += question[tag][0] - '0';}tag++;}}}//个人得分for (int i = 0; i < n; i++) {printf("%.1f\n", score[i]);}//错最多次数int max = 0;for (int i = 0; i < m; i++) {for (int j = 0; j < 5; j++) {if (total[i][j] > max) {max = total[i][j];}}}//全对情况if (max == 0) {cout << "Too simple" << endl;} else {for (int i = 0; i < m; i++) {for (int j = 0; j < 5; j++) {if (max == total[i][j]) {cout << max << " " << i + 1 << "-" << (char)(j + 'a') << endl;}}}}
}

这篇关于1073. 多选题常见计分法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/622726

相关文章

详解Linux中常见环境变量的特点与设置

《详解Linux中常见环境变量的特点与设置》环境变量是操作系统和用户设置的一些动态键值对,为运行的程序提供配置信息,理解环境变量对于系统管理、软件开发都很重要,下面小编就为大家详细介绍一下吧... 目录前言一、环境变量的概念二、常见的环境变量三、环境变量特点及其相关指令3.1 环境变量的全局性3.2、环境变

Java中常见队列举例详解(非线程安全)

《Java中常见队列举例详解(非线程安全)》队列用于模拟队列这种数据结构,队列通常是指先进先出的容器,:本文主要介绍Java中常见队列(非线程安全)的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一.队列定义 二.常见接口 三.常见实现类3.1 ArrayDeque3.1.1 实现原理3.1.2

MyBatis设计SQL返回布尔值(Boolean)的常见方法

《MyBatis设计SQL返回布尔值(Boolean)的常见方法》这篇文章主要为大家详细介绍了MyBatis设计SQL返回布尔值(Boolean)的几种常见方法,文中的示例代码讲解详细,感兴趣的小伙伴... 目录方案一:使用COUNT查询存在性(推荐)方案二:条件表达式直接返回布尔方案三:存在性检查(EXI

Python struct.unpack() 用法及常见错误详解

《Pythonstruct.unpack()用法及常见错误详解》struct.unpack()是Python中用于将二进制数据(字节序列)解析为Python数据类型的函数,通常与struct.pa... 目录一、函数语法二、格式字符串详解三、使用示例示例 1:解析整数和浮点数示例 2:解析字符串示例 3:解

MySQL查看表的最后一个ID的常见方法

《MySQL查看表的最后一个ID的常见方法》在使用MySQL数据库时,我们经常会遇到需要查看表中最后一个id值的场景,无论是为了调试、数据分析还是其他用途,了解如何快速获取最后一个id都是非常实用的技... 目录背景介绍方法一:使用MAX()函数示例代码解释适用场景方法二:按id降序排序并取第一条示例代码解

IDEA实现回退提交的git代码(四种常见场景)

《IDEA实现回退提交的git代码(四种常见场景)》:本文主要介绍IDEA实现回退提交的git代码(四种常见场景),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.已提交commit,还未push到远端(Undo Commit)2.已提交commit并push到

python进行while遍历的常见错误解析

《python进行while遍历的常见错误解析》在Python中选择合适的遍历方式需要综合考虑可读性、性能和具体需求,本文就来和大家讲解一下python中while遍历常见错误以及所有遍历方法的优缺点... 目录一、超出数组范围问题分析错误复现解决方法关键区别二、continue使用问题分析正确写法关键点三

JAVA数组中五种常见排序方法整理汇总

《JAVA数组中五种常见排序方法整理汇总》本文给大家分享五种常用的Java数组排序方法整理,每种方法结合示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录前言:法一:Arrays.sort()法二:冒泡排序法三:选择排序法四:反转排序法五:直接插入排序前言:几种常用的Java数组排序

正则表达式r前缀使用指南及如何避免常见错误

《正则表达式r前缀使用指南及如何避免常见错误》正则表达式是处理字符串的强大工具,但它常常伴随着转义字符的复杂性,本文将简洁地讲解r的作用、基本原理,以及如何在实际代码中避免常见错误,感兴趣的朋友一... 目录1. 字符串的双重翻译困境2. 为什么需要 r?3. 常见错误和正确用法4. Unicode 转换的

C语言中的常见进制转换详解(从二进制到十六进制)

《C语言中的常见进制转换详解(从二进制到十六进制)》进制转换是计算机编程中的一个常见任务,特别是在处理低级别的数据操作时,C语言作为一门底层编程语言,在进制转换方面提供了灵活的操作方式,今天,我们将深... 目录1、进制基础2、C语言中的进制转换2.1 从十进制转换为其他进制十进制转二进制十进制转八进制十进