-
题目描述:
-
输入N个学生的信息,然后进行查询。
-
输入:
-
输入的第一行为N,即学生的个数(N<=1000)
接下来的N行包括N个学生的信息,信息格式如下:01 李江 男 2102 刘唐 男 2303 张军 男 1904 王娜 女 19然后输入一个M(M<=10000),接下来会有M行,代表M次查询,每行输入一个学号,格式如下:02030104
-
输出:
-
输出M行,每行包括一个对应于查询的学生的信息。
如果没有对应的学生信息,则输出“No Answer!”
-
样例输入:
-
4 01 李江 男 21 02 刘唐 男 23 03 张军 男 19 04 王娜 女 19 5 02 03 01 04 03
-
样例输出:
-
02 刘唐 男 23 03 张军 男 19 01 李江 男 21 04 王娜 女 19 03 张军 男 19
-
来源:
题目分析:
1. 汉字的处理: 用scanf("%s")和printf("%s")即可。
2. 在WA了2次之后,发现number[] 和 name[]要足够大才行。(题目未明确给出范围)
3. 查找时,顺序查找即可。
源代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef struct student
{
char number[100];
char name[100];
char sex[10];
int age;
}student;
int main()
{
student stu[1005];
char num[10];
int n, m, i, j;
while(scanf("%d", &n) != EOF)
{
for(i = 0; i < n; i++)
scanf("%s%s%s%d", stu[i].number, &stu[i].name, stu[i].sex, &stu[i].age);
scanf("%d", &m);
for(j = 0; j < m; j++)
{
scanf("%s", num);
bool flag = false;
for(i = 0; i < n; i++)
if(!strcmp(num, stu[i].number))
{
flag = true;
break;
}
if(flag)
printf("%s %s %s %d\n", stu[i].number, stu[i].name, stu[i].sex, stu[i].age);
else
printf("No Answer!\n");
}
}
//system("pause");
return 0;
}
/**************************************************************
Problem: 1069
User: superlc320
Language: C++
Result: Accepted
Time:20 ms
Memory:1156 kb
****************************************************************/