Codeup:查找学生信息

题目描述

输入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<stdio.h>
#include<string.h>
const int maxn=1000;
struct Student{
	char num[10];
	char name[20];
	char sex[10];
	int age;
}stu[maxn];

int main(){
	int n;

	while(scanf("%d",&n)!=EOF){
		for(int i=0;i<n;i++){
			scanf("%s%s%s%d",stu[i].num,stu[i].name,stu[i].sex,&stu[i].age);
		}	
	char num1[100];	
	int m;
	int i;
		scanf("%d",&m);
		while(m--){
			scanf("%s",num1);	
			for(i=0;i<n;i++){
				if(!strcmp(stu[i].num,num1)){
				printf("%s %s %s %d\n",stu[i].num,stu[i].name,stu[i].sex,stu[i].age);
				break;
				}		
			}
			if(i==n) printf("No Answer!\n");	
			}
		}
	return 0;
}

首先写好输入,当查找的时候用for循环遍历全部已经存入的信息,和输入的信息使用strcmp()进行比较,注意strcmp()相等时返回0;大于返回正数,小于返回负数。
查找失败的时候:当i遍历全部0-n-1的数据后仍然没有找到,此时i=n,所以当i=n时没有找到该学生信息。
这道题真的是让我心力交瘁,做了一下午,难得不是实现,自己运行样例很正确,但是在codeup上测试就是答案错误,一直在找问题,最后花钱下载了测试数据和源码。发现数据里的名字一列最长有70多位远远超出我设置的数组大小,用string应该不用考虑这个问题,还有就是printf里面加了一个&一直没注意到,因为在编译器上没有报错,正常运行。
下面是两种答案:

#include<string.h>
int maxsize=1003;
typedef struct{
  char number[1000];
  char name[200];
  char sex[200];
  int age;
}StudentInfo;
int main(){
  int n, m, i, j;
  char search[1000];
  StudentInfo stdinfo[maxsize];
  while(scanf("%d", &n)==1){
    for(i=0; i<n; ++i){
      scanf("%s%s%s%d",stdinfo[i].number,stdinfo[i].name, stdinfo[i].sex, &stdinfo[i].age);
    }
    scanf("%d", &m);
    for(i=0; i<m; ++i){
      scanf("%s",search);
      for(j=0; j<n; ++j){
        if(strcmp(search, stdinfo[j].number)==0){ 
          printf("%s %s %s %d\n",stdinfo[j].number,stdinfo[j].name, stdinfo[j].sex, stdinfo[j].age);
          break;
        }
      }
      if(j==n) printf("No Answer!\n");
    }
  }
  return 0;
}

#include<string.h>

struct STU
{
	char id[100],name[100],sex[100];
	int age;
}stu[1000];

int main()
{
	int n,m,i;
	char s[100];
	while(scanf("%d",&n)!=EOF)
	{
		for(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);
		while(m--)
		{
			scanf("%s",s);
			for(i=0;i<n;i++){
			
				if(!strcmp(stu[i].id,s))
				{
					printf("%s %s %s %d\n",stu[i].id,stu[i].name,stu[i].sex,stu[i].age);
					break;
				}}
			if(i==n)
				puts("No Answer!");
		}
	}
	return 0;
}
发布了19 篇原创文章 · 获赞 2 · 访问量 752

猜你喜欢

转载自blog.csdn.net/zan1763921822/article/details/104130259