判断题的评判很简单,本题就要求你写个简单的程序帮助老师判题并统计学生们判断题的得分。
输入格式:
输入在第一行给出两个不超过 100 的正整数 N 和 M,分别是学生人数和判断题数量。第二行给出 M 个不超过 5 的正整数,是每道题的满分值。第三行给出每道题对应的正确答案,0 代表“非”,1 代表“是”。随后 N 行,每行给出一个学生的解答。数字间均以空格分隔。
输出格式:
按照输入的顺序输出每个学生的得分,每个分数占一行。
输入样例:
3 6
2 1 3 3 4 5
0 0 1 0 1 1
0 1 1 0 0 1
1 0 1 0 1 0
1 1 0 0 1 1
输出样例:
13
11
12
题解如下:
15/15 简单的嘞 一遍过,双重循环判断是否答对
/**
* 2024/04/15
* 15/15
*/
const readline = require("readline");
const rl = readline.createInterface({
input: process.stdin,
output: process.stdout,
});
let rows = [];
// 学生人数
let stuNum = 0;
// 满分数组
let fullMark;
// 答案数组
let rightAnswerArr = [];
let answerArr = [];
rl.on("line", function (data) {
rows.push(data);
if (rows.length === 1) {
stuNum = Number(data.split(" ")[0]);
} else if (rows.length === 2) {
fullMark = data.split(" ");
} else if (rows.length === 3) {
rightAnswerArr = data.split(" ");
} else {
answerArr.push(data.split(" "));
if (answerArr.length === stuNum) {
deal();
}
}
});
function deal() {
let markArr = new Array(stuNum).fill(0);
for (let i = 0; i < answerArr.length; i++) {
let el = answerArr[i];
for (let j = 0; j < el.length; j++) {
if (el[j] === rightAnswerArr[j]) {
markArr[i] += Number(fullMark[j]);
}
}
}
markArr.forEach((el) => {
console.log(el);
});
}