您的位置:首页 > 其它

PAT 1072. 开学寄语(20)

2018-03-05 09:02 204 查看
题目描述:

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

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

输入格式:

输入第一行给出两个正整数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

题目分析:

思路还是蛮清晰的,设置一个布尔型标记数组,读入待查验物品的编号后,用其作为下标,将对应数组元素更新为true。之后每次读入学生的物品后就按照编号查验flag标记为true的进行输出。并设置相应的变量进行设置。此外需注意的是,输出物品编号时,不足四位的要补上零。

#include<stdio.h>
#include<string.h>
const int maxn=10000;
int main()
{
int n,m,sumstu=0,sumwu=0;      //学生人数n,被查缴的物品数m,存在问题的学生人数sumstu,被收缴的物品数sumwu
bool ban[maxn]={false};        //标志禁止物品的数组ban
<
4000
span class="hljs-built_in">scanf("%d%d",&n,&m);
for(int i=0;i<m;i++){
int temp;
scanf("%d",&temp);         //读入禁止物品,并将相应的标记置为true
ban[temp]=true;
}
for(int i=0;i<n;i++){
char name[4];int num,flag=0;     //姓名数组name,学生所带物品数num,学生物品是否存在问题的标记
scanf("%s %d",name,&num);
for(int j=0;j<num;j++){
int wu;
scanf("%d",&wu);
if(ban[wu]){
sumwu++;         //查出一个,sumwu计数
if(flag==0){     //这是该学生第一个被查出的物品
printf("%s: %04d",name,wu);   //按照格式输出
flag=1;      //标记置为1
sumstu++;    //只在第一次被查出的时候,sumstu计数。
}
else{
printf(" %04d",wu);      //输出下一个被查出的物品编号。记得补足四位
}
}
}
if(flag==1){          //当学生物品有问题时,才需要输出换行
printf("\n");
}

}
printf("%d %d",sumstu,sumwu);    //输出存在物品问题的学生人数,被收缴的物品数。
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  PAT