题目链接:
https://pintia.cn/problem-sets/994805260223102976/problems/994805268817231872
AC代码:
#include <bits/stdc++.h>
using namespace std;
const int maxn=110;
int correct[maxn],fenshu[maxn],judge[maxn];
int main(){
int N,M;
scanf("%d%d",&N,&M);
for(int i=0;i<M;i++){
scanf("%d",&fenshu[i]);
}
for(int i=0;i<M;i++){
scanf("%d",&correct[i]);
}
for(int i=0;i<N;i++){
int sum=0;
for(int i=0;i<M;i++){
scanf("%d",&judge[i]);
if(judge[i]==correct[i])
sum+=fenshu[i];
}
printf("%d\n",sum);
}
}
二刷:
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <vector>
using namespace std;
int main(){
int N,M;
int i,j;
scanf("%d%d",&N,&M);
vector<int> score(M),cor(M);
for(i=0;i<M;i++){
scanf("%d",&score[i]);
}
for(i=0;i<M;i++){
scanf("%d",&cor[i]);
}
int sum=0,tmp;
for(i=0;i<N;i++){
sum=0;
for(j=0;j<M;j++){
scanf("%d",&tmp);
if(tmp==cor[j])
sum+=score[j];
}
printf("%d\n",sum);
}
return 0;
}