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


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

    题干

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

    123

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

    输入格式:

    输入第一行给出两个正整数 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("
    ");
    		}
    		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
  • 相关阅读:
    致敬尤雨溪,Vue.js 让我赚到了第一桶金
    JavaScript 构造树形结构的一种高效算法
    Webpack 4 Tree Shaking 终极优化指南
    腾讯前端面试题:一言不合就写个五子棋
    使用Web代理实现Ajax跨域
    Extjs 4 chart自定义坐标轴刻度
    五分钟了解浏览器的工作原理
    面试官:JavaScript 原始数据类型 Symbol 有什么用?
    JavaScript 初学者容易犯的几个错误,你中招没?
    帮助你更好的理解Spring循环依赖
  • 原文地址:https://www.cnblogs.com/cell-coder/p/12642527.html
Copyright © 2020-2023  润新知