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的进行输出。并设置相应的变量进行设置。此外需注意的是,输出物品编号时,不足四位的要补上零。
下图是上海某校的新学期开学寄语:天将降大任于斯人也,必先删其微博,卸其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 (Basic Level) Practise (中文)1072. 开学寄语(20)
- pat乙级1072. 开学寄语(20)
- PAT 1072. 开学寄语(20) JAVA
- PAT乙级1072. 开学寄语(20)
- pat 乙级 1072. 开学寄语(20)
- PAT 乙级 1072. 开学寄语(20)
- pat乙级真题 1072. 开学寄语(20)
- java 解决 pat 乙级 1072. 开学寄语(20)
- PAT (Basic Level) Practise (中文)1072. 开学寄语(20)
- 1072. 开学寄语(20) PAT乙级真题
- PAT 1072. 开学寄语(20)-PAT乙级真题
- 乙级 PAT 1072. 开学寄语(20)
- 1072. 开学寄语(20)
- 1072. 开学寄语(20)
- 1072. 开学寄语(20)
- 1072. 开学寄语(20)
- 1072. 开学寄语(20)
- 1072. 开学寄语(20)
- 1072. 开学寄语(20)
- PAT乙级 1072 开学寄语