#include <stdio.h>
struct Index{
char name[20];
char birth[20];
char sex[20];
char tel[20];
char mob[20];
};//联系人信息的结构体
int N;
struct Index t;
struct Index *p = &t;/*设置这些全局变量的
目的是方便用search函数 */
void search(int n);
int main()
{
int K,num[100]={0};
scanf("%d",&N);
for(int i=0;i<N;i++)
scanf("%s %s %s %s %s\n",(p+i)->name,(p+i)->birth,(p+i)->sex,(p+i)->tel,(p+i)->mob);
//录入N个人的信息
scanf("%d",&K);// 录入要查询的人数目K
for(int j=0;j<K;j++)
scanf("%d",&num[j]);//输入K个待查询编号
for(int k=0;k<K;k++)
search(num[k]); //查询
return 0;
}
void search(int n){
if(n>=0&&n<N)
printf("%s %s %s %s %s\n",(p+n)->name,(p+n)->tel,(p+n)->mob,(p+n)->sex,(p+n)->birth);
else
printf("Not Found\n");
}//(p+n)与前面的(p+i)一样,都是由n或i的不同指向不同的联系人结构体
刚刚复习了结构体和函数,结构体与指针,于是练练手,代码如上
通讯录中的一条记录包含下述基本信息:朋友的姓名、出生日期、性别、固定电话号码、移动电话号码。
本题要求编写程序,录入N条记录,并且根据要求显示任意某条记录。
输入格式:
输入在第一行给出正整数N(≤10);随后N行,每行按照格式姓名 生日 性别 固话 手机
给出一条记录。其中姓名
是不超过10个字符、不包含空格的非空字符串;生日按yyyy/mm/dd
的格式给出年月日;性别用M
表示“男”、F
表示“女”;固话
和手机
均为不超过15位的连续数字,前面有可能出现+
。
在通讯录记录输入完成后,最后一行给出正整数K,并且随后给出K个整数,表示要查询的记录编号(从0到N−1顺序编号)。数字间以空格分隔。
输出格式:
对每一条要查询的记录编号,在一行中按照姓名 固话 手机 性别 生日
的格式输出该记录。若要查询的记录不存在,则输出Not Found
。
反思:
1.输出顺序要求与输入不一样,易忽略
2.for遍历输入数组时,num[for变量]错写为num[边界条件变量],导致浪费大量时间debug,最后发现是这种马虎问题,实在不应该
3.输入输出结构体时,最好将多个成员放在同一个scanf下,便于格式化输入,否则用多个scanf时,容易产生空格和换行等导致bug