L4-106 判断题(15分) c++代码

本文介绍了一个编程题目,要求编写一个程序,根据给定的判断题答案和学生答案,计算并输出每个学生的得分。程序通过输入学生人数、判断题数量、题满分值和答案,计算并输出对应得分。

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

输入格式:

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

 代码:

//#include<iostream>
//#include<cstring>
//#include<cmath>
//#include<algorithm>
//#include<ctype.h>
//#include<stdio.h>
//#include<map>
#include<bits/stdc++.h>
using namespace std;

int main(){
	int n,m;
	cin>>n>>m;
	int ans[m],p[m],stu[n]={0};
	for(int i=0;i<m;i++) cin>>p[i];
	for(int i=0;i<m;i++) cin>>ans[i];
	for(int i=0;i<n;i++){
		for(int j=0;j<m;j++){
			int s;
			cin>>s;
			if(s==ans[j]) stu[i]+=p[j];
		}
		cout<<stu[i]<<endl;
	}
	return 0;
}

### 问题析 `GESP202312-L4T1 小杨的字典` 是一道字符串处理与映射查询类问题。题目要求根据一个给定的字典,将输入字符串中的单词进行替换,若单词不在字典中,则输出 `"UNK"`。 输入格式包括: - 第一行一个整数 `n` 表示字典条目数量; - 接下来 `n` 行,每行两个字符串,表示英文单词和对应的中文翻译; - 最后一行是待翻译的字符串。 输出要求是将字符串中的每个英文单词替换为对应的翻译,非字母字符原样输出。 ### 解题思路 使用 `map<string, string>` 存储字典,可以实现高效的单词查找与替换。遍历输入字符串时,逐个字符读取,若为字母则拼接成单词,否则触发翻译逻辑。翻译时检查单词是否存在于字典中,并输出对应翻译或 `"UNK"`,非字母字符直接输出[^2]。 ### 示例代码 ```cpp #include <bits/stdc++.h> using namespace std; map<string, string> m; int n; string a, b, s, x; int main() { cin >> n; for (int i = 1; i <= n; i++) { cin >> a >> b; m[a] = b; } cin >> s; for (int i = 0; i < s.size(); i++) { if (s[i] >= 'a' && s[i] <= 'z') { x += s[i]; } else { if (x != "") { if (m.count(x)) { cout << m[x]; } else { cout << "UNK"; } } cout << s[i]; x = ""; } } if (x != "") { if (m.count(x)) { cout << m[x]; } else { cout << "UNK"; } } return 0; } ``` ### 代码说明 - 使用 `map<string, string>` 存储字典条目,便于快速查找对应翻译; - 遍历输入字符串时,使用变量 `x` 拼接连续的字母字符; - 遇到非字母字符时,触发翻译逻辑并输出结果; - 最后检查是否仍有未处理的单词,避免遗漏[^2]。 ### 注意事项 - 字典大小写敏感,题目中仅处理小写字母; - 输入字符串中单词可能被非字母字符隔,如空格、标点等; - 输出需保持非字母字符原样,翻译后的单词与非字母字符之间无额外空格。 ### 相关问题 1. 如何使用 `map` 实现单词翻译查询? 2. 字符串拼接与隔处理的常见技巧有哪些? 3. 如何处理字符串末尾未触发翻译的单词? 4. C++ 中如何高效处理输入输出流? 5. 如何优化字典查询效率?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值