#include
#include
struct info
{
char name[20];
char tel[20];
} person[4]; //一般定义结构体最好放到main函数的外面,这样结构清晰
int main()//最好把void换为int,不过你那样也对,这只是我的习惯
{
int i,j;
char findname[20];
char empty[20]=" ";
char a[20]="break";//我其实没理解你这是干什么的,反正应该不是你的问题
printf("please input a list\n");
for(i=0; i<4; i++)
scanf("%s %s",person[i].name,person[i].tel);//去掉&,字符串不需要,这里你最好再看一下字符串,
while(strcmp(findname,a)!=0)
{
printf("\nPlease input a name\n");
gets(findname);//scanf 会自动跳过空格,所以换成gets
for(i=0; i<4; i++)
{
if(strcmp(findname,person[i].name)==0)
{
printf("%s\n",person[i].tel);
break;
}
if(strcmp(findname,empty)==0)
{
for(j=0; j<4; j++)
printf("%s %s\n",person[j].name,person[j].tel);
break;
}
}
}
return 0;
}
scanf()函数不能输入空格,
两种改法:
一、你只能换一下了
char empty[20]="*";
输入* 可以达到效果
或者
二、
把scanf("%s",&findname);改成
gets(findname);
查找姓名那一部分
printf("\nPlease input a name\n");
scanf("%s",&findname);//把scanf改为gets
因为scanf()是不能存储空格的。
你这个逻辑写的很混乱。在C语言中,你的结构要很清晰才行。while(strcmp(findname,a)!=0)
{
printf("\nPlease input a name\n");
scanf("%s",&findname);
这一段,你的比较不觉得有问题吗?