查找学生信息
题目描述
输入N个学生的信息,然后进行查询。
输入
输入的第一行为N,即学生的个数(N<=1000)
接下来的N行包括N个学生的信息,信息格式如下:
01 李江 男 21
02 刘唐 男 23
03 张军 男 19
04 王娜 女 19
然后输入一个M(M<=10000),接下来会有M行,代表M次查询,每行输入一个学号,格式如下:
02
03
01
04
输出
输出M行,每行包括一个对应于查询的学生的信息。
如果没有对应的学生信息,则输出“No Answer!”
样例输入
5
001 张三 男 19
002 李四 男 20
003 王五 男 18
004 赵六 女 17
005 刘七 女 21
7
003
002
005
004
003
001
006
样例输出
003 王五 男 18
002 李四 男 20
005 刘七 女 21
004 赵六 女 17
003 王五 男 18
001 张三 男 19
No Answer!
/*查找学生信息
* 1.首先确定需要一个结构体来存储学生信息,
设置一个结构体数组stu,将n个学生的信息存储在结构体数组中
2.将m个待查学号存储在数组number中
3.依次遍历number中每一个学号,每一个学号都会遍历一次结构体数组,
直到找到待查学号停止
*/
#include<stdio.h>
#include<string.h>
#define maxN 1000
struct student
{
char id[10]; //学号
char name[100]; //姓名
char gender[50]; //性别
int age; //年龄
};
struct student stu[maxN];
int main()
{
int N,M;
while(scanf("%d",&N)!=EOF)//输入N
{
if(N<1||N>1000)
{
printf("N ERROR\n");
return 0;
}
for(int i=0; i<N; i++)//输入N个学生信息
{
scanf("%s%s%s%d",stu[i].id,stu[i].name,stu[i].gender,&stu[i].age);
}
scanf("%d",&M);//输入M
if(M<1||M>10000)
{
printf("M ERROR\n");
return 0;
}
char number[10000][10];//输入待查找学生学号
for(int i=0; i<M; i++)
{
scanf("%s",number[i]);
}
int flag;
for(int i=0; i<M; i++)
{
flag=0;
for(int j=0; j<N; j++)
{
if(!strcmp(stu[j].id,number[i]))
{
flag=1;
printf("%s %s %s %d\n",stu[j].id,stu[j].name,stu[j].gender,stu[j].age);
break;//细节,学号的唯一性,若查找到则直接退出
}
}
if(!flag)
printf("No Answer!\n");
}
}
return 0;
}