算法笔记——Codeup Contest 100000576 Problem C 查找学生信息

题目描述
输入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!

代码

#include <cstdio>
#include <cstring>	
struct stuinfo {
	char id[10];								//id长度 
	char name[100];								//name长度 
	char sex[20];								//sex长度 
	int age;
} stu[1005];
int main () {
	int n,m ;
	while (scanf ("%d", &n) != EOF) {			//多组数据 
		for (int i=0; i<n; i++) {
			scanf ("%s %s %s %d", stu[i].id, stu[i].name, stu[i].sex, &stu[i].age) ;
		}
		scanf ("%d", &m) ;
		char temp[10] ;
		for (int i=0; i<m; i++) {				//要进行m次查询 因此这个是最大的括号 之前把for循环放在外面就不能查询m次了 
			scanf ("%s", temp) ;	
			for (int j=0; j<n; j++) {
				if (strcmp(temp,stu[j].id) == 0) {
					printf ("%s %s %s %d\n", stu[j].id, stu[j].name, stu[j].sex, stu[j].age) ;
					break ;
				} else if(strcmp(temp,stu[j].id) != 0 && j==n-1){
					printf ("No Answer!\n") ;
				}
			}	
		}
	}
	return 0 ;
}

猜你喜欢

转载自blog.csdn.net/arthur01p/article/details/86555665