whenever

  • Home

  • Tags21

  • Categories6

  • Archives122

  • About

PAT乙级1061 || 判断题(详解,C/C++示例,测试点分析)

Posted on 2019-10-07 In PAT

判断题

题目描述

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

输入格式

输入在第一行给出两个不超过 100 的正整数 N 和 M,分别是学生人数和判断题数量。第二行给出 M 个不超过 5 的正整数,是每道题的满分值。第三行给出每道题对应的正确答案,0 代表“非”,1 代表“是”。随后 N 行,每行给出一个学生的解答。数字间均以空格分隔。

输出格式

按照输入的顺序输出每个学生的得分,每个分数占一行。

输入样例

1
2
3
4
5
6
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

输出样例

1
2
3
13
11
12

问题解决

解题思想

简单的逻辑题,按要求统计处理输出即可。判断某同学的答案是否正确时,可以用下方代码的==

1
if(a == ans[j])

也可用异或运算符^

1
if(!(a ^ ans[j]))

代码示例(C/C++)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#include <cstdio>
using namespace std;
int main()
{
int n,m,tc[100],ans[100]; //数组tc为满分值,ans为正确答案
scanf("%d%d",&n,&m);
for(int i = 0; i < m; i++) {
scanf("%d",&tc[i]);
}
for(int i = 0; i < m; i++) {
scanf("%d",&ans[i]);
}
for(int i = 0; i < n; i++) {
int sum = 0,a; //sum统计每个学生的得分,a临时存入选择
for(int j = 0; j < m; j++) {
scanf("%d",&a);
if(a == ans[j]){
sum += tc[j];
}
}
printf("%d\n",sum);
}
return 0;
}

题目来源:PAT乙级1061
作者:CHEN, Yue
单位:浙江大学

稀罕作者
Mengzhao Wang WeChat Pay

WeChat Pay

Mengzhao Wang Alipay

Alipay

# C/C++ # PAT # 编程
PAT乙级1060 || 爱丁顿数(详解,C/C++示例,测试点分析)
PAT乙级1062 || 最简分数(详解,C/C++示例,测试点分析)
  • Table of Contents
  • Overview
Mengzhao Wang

Mengzhao Wang

Try? All the way !
122 posts
6 categories
21 tags
  1. 1. 判断题
    1. 1.1. 题目描述
    2. 1.2. 输入格式
    3. 1.3. 输出格式
    4. 1.4. 输入样例
    5. 1.5. 输出样例
    6. 1.6. 问题解决
      1. 1.6.1. 解题思想
      2. 1.6.2. 代码示例(C/C++)
© 2021 Mengzhao Wang