7-34 通讯录的录入与显示

通讯录中的一条记录包含下述基本信息:朋友的姓名、出生日期、性别、固定电话号码、移动电话号码。 本题要求编写程序,录入N条记录,并且根据要求显示任意某条记录。

输入格式

输入在第一行给出正整数N(≤10);随后N行,每行按照格式姓名 生日 性别 固话 手机给出一条记录。其中姓名是不超过10个字符、不包含空格的非空字符串;生日按yyyy/mm/dd的格式给出年月日;性别用M表示“男”、F表示“女”;固话手机均为不超过15位的连续数字,前面有可能出现+

在通讯录记录输入完成后,最后一行给出正整数K,并且随后给出K个整数,表示要查询的记录编号(从0到N−1顺序编号)。数字间以空格分隔。

输出格式

对每一条要查询的记录编号,在一行中按照姓名 固话 手机 性别 生日的格式输出该记录。若要查询的记录不存在,则输出Not Found

输入样例

3
Chris 1984/03/10 F +86181779452 13707010007
LaoLao 1967/11/30 F 057187951100 +8618618623333
QiaoLin 1980/01/01 M 84172333 10086
2 1 7

输出样例

LaoLao 057187951100 +8618618623333 F 1967/11/30
Not Found

分析与答案

用一个动态分配内存的结构体数组来储存通讯录记录,每一项都作为字符串(或字符,性别只有一个字母)来处理。注意输入和输出的次序是不一样的。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

typedef struct{
    char name[11];
    char birth[11];
    char sex;
    char tele[17];
    char mobile[17];    
}contact;

int main(){
    int n,i = 0;
    scanf("%d",&n);
    contact * list = (contact*)malloc(n*sizeof(contact));
    for(;i<n;i++){
        scanf("%s %s %c %s %s",(list+i)->name,(list+i)->birth,&(list+i)->sex,(list+i)->tele,(list+i)->mobile);
    }
    int num;
    int * lookup;
    scanf("%d",&num);
    lookup = (int*)malloc(num*sizeof(int));
    for(i=0;i<num;i++){
        scanf("%d",lookup+i);
    }
    for(i=0;i<num;i++){
        if(*(lookup+i)>=n||*(lookup+i)<0){
            printf("Not Found");
        }
        else{
            printf("%s %s %s %c %s",(list+*(lookup+i))->name,(list+*(lookup+i))->tele,(list+*(lookup+i))->mobile,(list+*(lookup+i))->sex,
                (list+*(lookup+i))->birth);
        }
        if(i!=num-1)
            printf("\n");
    }
    return 0;
}

7-34 测试点