PAT乙级:1072开学寄语(20分)

时间:2023-03-09 01:50:34
PAT乙级:1072开学寄语(20分)

PAT乙级:1072开学寄语(20分)

题干

下图是上海某校的新学期开学寄语:天将降大任于斯人也,必先删其微博,卸其 QQ,封其电脑,夺其手机,收其 ipad,断其 wifi,使其百无聊赖,然后,净面、理发、整衣,然后思过、读书、锻炼、明智、开悟、精进。而后必成大器也!

PAT乙级:1072开学寄语(20分)

本题要求你写个程序帮助这所学校的老师检查所有学生的物品,以助其成大器。

输入格式:

输入第一行给出两个正整数 N(≤ 1000)和 M(≤ 6),分别是学生人数和需要被查缴的物品种类数。第二行给出 M 个需要被查缴的物品编号,其中编号为 4 位数字。随后 N 行,每行给出一位学生的姓名缩写(由 1-4 个大写英文字母组成)、个人物品数量 K(0 ≤ K ≤ 10)、以及 K 个物品的编号。

输出格式:

顺次检查每个学生携带的物品,如果有需要被查缴的物品存在,则按以下格式输出该生的信息和其需要被查缴的物品的信息(注意行末不得有多余空格):

姓名缩写: 物品编号1 物品编号2 ……

最后一行输出存在问题的学生的总人数和被查缴物品的总数。

输入样例:

4 2
2333 6666
CYLL 3 1234 2345 3456
U 4 9966 6666 8888 6666
GG 2 2333 7777
JJ 3 0012 6666 2333

输出样例:

U: 6666 6666
GG: 2333
JJ: 6666 2333
3 5

思路

比较简单。用unordered_map记录一下违规编号。再每个学生记录一下有没有违规再输出即可

code

#include<iostream>
#include<unordered_map>
#include<vector>
using namespace std;
int main(){
int no_student=0,no_sub=0,cnt_sub=0,cnt_stu=0,temp_no,temp_subno;
string temp_stu_name;
unordered_map<int,bool> memo;
cin>>no_student>>no_sub;
for(int i=0;i<no_sub;i++){
cin>>temp_no;
memo[temp_no]=true;
}
vector<int> temp_memo;
for(int i=0;i<no_student;i++){
cin>>temp_stu_name>>temp_subno;
for(int j=0;j<temp_subno;j++){
cin>>temp_no;
if(memo[temp_no]) temp_memo.push_back(temp_no);
}
if(!temp_memo.empty()){
cnt_stu++,cnt_sub+=temp_memo.size();
cout<<temp_stu_name<<":";
for(int no:temp_memo) printf(" %04d",no);
printf("\n");
}
temp_memo.clear();
}
printf("%d %d",cnt_stu,cnt_sub);
return 0;
}

结果

提交时间 状态 分数 题目 编译器 耗时 用户
2020/4/6 16:03:12 答案正确 20 1072 C++ (g++) 11 ms a man
测试点 结果 耗时 内存
0 答案正确 4 ms 424 KB
1 答案正确 4 ms 384 KB
2 答案正确 4 ms 384 KB
3 答案正确 11 ms 640 KB