【JAVA】PAT 乙级 1061 判断题
题目链接
判断题的评判很简单,本题就要求你写个简单的程序帮助老师判题并统计学生们判断题的得分。
输入格式:
输入在第一行给出两个不超过 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
这题比较简单(至少比之前那道1058 选择题要简单)
用两个数组f和ans分别存储分数和答案
然后对于每行学生的回答,与ans中相应元素做对比就可以了
AC代码:
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.io.StreamTokenizer;
public class Main{
public static void main(String[] args) throws Exception {
BufferedReader bf = new BufferedReader(new InputStreamReader(System.in));
PrintWriter out = new PrintWriter(new OutputStreamWriter(System.out));
StreamTokenizer in = new StreamTokenizer(bf);
in.nextToken();
int n = (int) in.nval;
in.nextToken();
int m = (int) in.nval;
int[] f = new int[m];
int[] ans = new int[m];
for (int i = 0; i < m; i++) {
in.nextToken();
f[i] = (int) in.nval;
}
for (int i = 0; i < m; i++) {
in.nextToken();
ans[i] = (int) in.nval;
}
for (int i = 0; i < n; i++) {
int r = 0;
for (int j = 0; j < m; j++) {
in.nextToken();
int tan = (int) in.nval;
if (tan == ans[j]) {
r += f[j];
}
}
out.println(r);
}
out.flush();
}
}