B1061 判断题 (15分)

判断题的评判很简单,本题就要求你写个简单的程序帮助老师判题并统计学生们判断题的得分。

输入格式:

输入在第一行给出两个不超过 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

思考

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

AC代码

#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<cstdlib>
using namespace std;
int main(void){
int n,m,sum=0;
scanf("%d %d", &n,&m);
int *pro_ans;
int *goal;
int *ans;
pro_ans = new int[m];
goal = new int[m];
ans = new int[m];
for(int i = 0;i<m;i++){
scanf("%d", &goal[i]);
}
for(int i = 0;i<m;i++){
scanf("%d", &pro_ans[i]);
}
for(int i=0;i<n;i++){
sum = 0;
for(int j=0;j<m;j++){
scanf("%d", &ans[j]);
if(ans[j]==pro_ans[j]){
sum+=goal[j];
}
}
printf("%d\n", sum);
}
delete [] pro_ans;
delete [] goal;
delete [] ans;
return 0;
}
05-11 19:19