| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2614 人关注过本帖
标题:'inf' : is not a member of 'node'
只看楼主 加入收藏
qwer2341
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2015-5-28
结帖率:0
收藏
已结贴  问题点数:20 回复次数:2 
'inf' : is not a member of 'node'
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<conio.h>/*屏幕操作函数库*/
#define HEADER1 "------------------------------图书信息----------------------------------------\n"
#define HEADER2 " |   编号   |      书名     | 价格|      作者     |       出版社       |数量  |\n"
#define HEADER3 " |----------|---------------|-----|---------------|--------------------|------|\n"
#define HEADER4 " ------------------------------会员信息---------------------------------------\n"
#define HEADER5 " |   编号   |    姓名       |   电话   |\n"
#define HEADER6 " |----------|---------------|---------------|\n"
#define HEADER7 " | 会员编号 |   会员姓名    | 图书编号 |    图书名称   |\n"
#define HEADER8 " |----------|---------------|----------|---------------|\n"
#define HEADER9 " |-----------------borrow book-------------------------|\n"
#define FORMAT  " |%-10s|%-15s|%5d|%-15s|%-20s|%5d |\n"
#define FORMAT1  " |%-10s|%-15s|%-15s|\n"
#define FORMAT2  " |%-10s|%-15s|%-10s|%-15s|\n"
#define DATA p->data.num,p->data.name,p->data.price,p->data.author,p->data.pub,p->data.number #define END     " ------------------------------------------------------------------------\n"
 #define N 100
typedef struct book
{
char num[10]; /*书号*/
 char name[15]; /*书名*/
int   price; /*定价*/
 char author[15]; /*作者*/
 char pub[20]; /*出版社*/
int number;/*数量*/
 int bnumber;/*借出次数*/
};

typedef struct Member
 {
 char  mnum[10];/*会员号*/
 char mname[15];/*会员姓名*/
 char mtel[15];/*联系电话*/ };

 typedef struct borrow
 {
 char mnum[10];/*会员号*/
 char mname[15];/*会员姓名*/  
 char num[10];/*书号*/  
 char name[15];/*书名*/
 };

 typedef struct node/*定义图书信息链表的结点结构*/
 {
 struct book data; /*数据域*/  
 struct node *next;    /*指针域*/
}Node,*Link;   /*定义node类型的结构变量及指针变量*/
 
typedef struct mnode/*定义会员信息链表的结点结构*/
{
 struct Member inf;  
struct mnode *next;
}Mnode,*Mlink;
typedef struct bnode/*定义借书信息链表的结点结构*/
 {  
struct borrow binf;  
struct bnode *next;
 }Bnode,*Blink;
void menu() /*主菜单*/
{  
system("cls");   /*清屏*/
 printf("                               图书管理系统\n");   
 printf("\t*************************菜单**********************************\n");   
 printf("\t* 1 添加图书信息               2 删除图书信息           *\n");   
 printf("\t* 3 查询图书信息               4 修改图书信息      *\n");
printf("\t* 5 添加会员                   6 借书                   *\n");
printf("\t* 7 还书                       8 按借出次数查看图书     *\n");
printf("\t* 9 按入馆时间查看图书         0 退出系统               *\n");  
printf("\t***************************************************************\n");
}
void printheader() /*格式化输出表头*/
{
 printf(HEADER1);
 printf(HEADER2);  
 printf(HEADER3);
 }
void printdata(Node *pp) /*格式化输出表中数据*/
{  
Node *p;
  p=pp;
 printf("FORMAT,DATA");
  }
 void printbdata(Node *pp)
 {
}  
void Wrong() /*输出按键错误信息*/
{  
printf("\n\n\n\n\n***********Error:input has wrong! press any key to continue**********\n");  getchar();
}  
void Nofind() /*输出未查找此学生的信息*/
{  
printf("\n=====>Not find this record!\n");
}
void Savemember(Mlink m)
{  
FILE *fp;  Mnode *p;
 int count=0;
 fp=fopen("f:\\member.txt","wb");/*以只写方式打开二进制文件*/
 if(fp==NULL) /*打开文件失败*/  
{   
printf("\n=====>open file error!\n");
 getchar();  
 return;  
}
 p=m->next;   
 while(p)
{   
if(fwrite(p,sizeof(Mnode),1,fp)==1)/*写记录到磁盘文件中*/
 {  
  p=p->next;   
 count++;   
}   else
  {
break;  
 }
 }
 
if(count>0)
 {
   getchar();
   printf("\n\n\n\t保存文件完成,总共保存的数量是:%d\n",count);
   getchar();
  }  
else
 {
system("cls");
 getchar();
 }  
fclose(fp);
 }
void Save(Link l)/*将数据存盘*/
{  
FILE *fp;
 Node *p;
  int count=0;
 fp=fopen("f:\\book.txt","wb");/*以只写方式打开二进制文件*/
  if(fp==NULL) /*打开文件失败*/
  {
  printf("\n=====>open file error!\n");
  getchar();
  return;
  }
 p=l->next;   
 while(p)  {
if(fwrite(p,sizeof(Node),1,fp)==1)/*写记录到磁盘文件中*/
  {  
  p=p->next;  
  count++;
  }  
 else  
 {  
  break;  
 }
 }
 if(count>0)
  {
  getchar();
   printf("\n\n\n\t=====>保存文件完成,保存的图书信息数量是:%d\n",count);  
 getchar();
 }  
else
 {system("cls");
  printf("the current link is empty,no student record is saved!\n");
 getchar();
 }
 fclose(fp);
 }
void Disp(Link l) /*显示单链表l中存储的图书记录*/
{  
Node *p;
p=l->next;
if(!p) /*p==NULL则说明暂无记录*/
  {
 printf("\n=====>Not  record!\n");
  getchar();
  return;
 }   
 printf("\n\n");
  printf(HEADER1);
  printf(HEADER2);
  printf(HEADER3);
while(p)    /*逐条输出链表中存储图书信息*/
 {
  printf("FORMAT,DATA");
  p=p->next;
  printf(HEADER3);
  }  
getchar();
}
void Disp1(Link l) /*显示单链表l中存储的图书记录*/
{
  system("cls");
  Node *p;
  p=l->next;
if(!p) /*p==NULL则说明暂无记录*/
  {
  printf("\n=====>Not  record!\n");  
 getchar();
   return;
 }   
 printf("\n\n");
printf(HEADER1);
printf(HEADER2);
printf(HEADER3);   
 while(p)    /*逐条输出链表中存储图书信息*/
 {
  printf("FORMAT,DATA");
   p=p->next;
   printf(HEADER3);
 }  
printf("press any key to menu");
 fflush(stdin);
 getchar();
 return;
 }
void Mdisp(Mlink m) /*显示单链表中存储的会员信息*/
{  
Mnode *p;
p=m->next;
if(!p) /*p==NULL证明没有会员记录*/  
{
  printf("\n=====>Not  record!\n");
  getchar();
  return;
 }   
 printf("\n\n");
 printf(HEADER4);
 printf(HEADER5);
 printf(HEADER6);  
 
while(p)    /*逐条输出链表中存储的会员信息*/
 {
  printf(FORMAT1,p->inf.mnum,p->inf.mname,p->inf.mtel);
  p=p->next;
 printf(HEADER6);
 }
 getchar();
 }
Node* Locate(Link l,char findmess[],char nameornum[])
{
  Node *r;
 if(strcmp(nameornum,"num")==0) /*按书号查询*/
 {
   r=l->next;
  while(r)
  {    if(strcmp(r->data.num,findmess)==0)   
  return r;/*返回与输入内容相匹配的结点*/
   r=r->next;
  }
 }
else if(strcmp(nameornum,"name")==0) /*按书名查询*/
  {
  r=l->next;
  while(r)
   {   
 if(strcmp(r->data.name,findmess)==0)
return r;/*返回与输入内容相匹配的结点*/  
  r=r->next;
  }
 }
 return 0; /*若未找到,返回一个空指针*/
}
void stringinput(char *t,int lens,char *notice)/*输入字符串,并进行长度验证*/
 {
 char n[50];
do{   
    printf(notice); /*显示提示信息*/
   scanf("%s",n); /*输入字符串*/
  if(strlen(n)>lens)
 printf("\n 超过长度规定值! \n"); /*进行长度是否超过规定值*/
 }while(strlen(n)>lens);
 strcpy(t,n); /*将输入的字符串拷贝到字符串t中*/
}
int numberinput(char *notice)
 {
 int t=0;
 do{   printf(notice); /*显示提示信息*/
scanf("%d",&t); /*输入图书数量*/
  if (t<0) printf("\n price must >0! \n");
 }while(t<0);
 return t;
}
 void Add(Link l)/*增加图书记录*/
{
 Node *p,*r,*s;
 char ch,flag=0,num[10];
  r=l;
 s=l->next;
 system("cls");/*清屏*/
 Disp(l); /*先输出已有的图书信息*/
 while(r->next!=NULL)
  r=r->next; /*将指针移至于链表最末尾,准备添加记录*/  
while(1) /*可输入多条记录,输入0时退出添加操作*/
 {   
while(1)
  {   
stringinput(num,10,"输入新增图书编号(输入 '0'return menu):"); /*输入书号*/   
 flag=0;
   if(strcmp(num,"0")==0) /*输入0退出操作,返回菜单界面*/   
 {   Save(l);return;}   
 s=l->next;
while(s) /*查询输入的书号是否已经存在*/  
 {     
if(strcmp(s->data.num,num)==0)
{     
flag=1;
    break;
    }   
  s=s->next;
   }         
   if(flag==1) /*提示用户是否重新输入*/      
   {
getchar();
printf("=====>输入的书号 %s 错误,是否重新输入 (y/n):",num);
   scanf("%c",&ch);   
if(ch=='y'||ch=='Y')  
   continue;  
  else  
   return;
  }   
else  
  {break;}
  }
p=(node *)malloc(sizeof(Mnode)); /*申请内存空间*/
   if(!p)
  {
   printf("\n allocate memory failure "); /*如没有申请到,输出提示信息*/
   return;              /*返回主界面*/
  }
strcpy(p->inf.mnum,num); /*将会员号拷贝到p->data.num中*/
stringinput(p->inf.mname,15,"姓名:");
stringinput(p->inf.tel,15,"电话:");  
 p->next=NULL;
  r->next=p; /*将新结点插入链表中*/
   r=p;  
}  
return;
 }
void searchbnum(Link l)
{   
  Node *p;
    int count=0;
 int count1=0;
  int bnum[100];  
int maxnum=0;
 int thismax=0;
 p=l->next;
 system("cls");
if(!l->next) /*若链表为空*/
 {  
 system("cls");
  printf("\n=====>No record!\n");
getchar();
 return;
 }
 printf(" ------------------------------图书信息----------------------------------------\n");
 printf(" |借出次数|   编号   |    书名       | 价格|    作者   |     出版社     |数量  |\n");  
 while(p)  
{      
if(p->data.bnumber>=maxnum){  
   //bnum[i]=p->data.bnumber;
   maxnum=p->data.bnumber;
  }  
        count1++;   
p=p->next;  
}  
 while(true)
 {
  p=l->next;
   while(p)
  {   
 if(p->data.bnumber==maxnum)
{   
 printf("|%-8d|%-10s|%-15s|%-5d|%-11s|%-16s|%-6d|\n",p->data.bnumber,p->data.num,p->data.name,p->data.price,p->data.author,p->data.pub,p->data.number);  
     count++;  
 }   
if(p->data.bnumber<maxnum&&p->data.bnumber>thismax)  
 {  
  thismax=p->data.bnumber;
   }  
 p=p->next;  
  }
   if(count==count1)
   {  
 break;
  }  
 maxnum=thismax;
  thismax=0;  
}
 printf(" |--------|----------|---------------|-----|-----------|----------------|------|\n");
 printf("press any key to return");
  fflush(stdin);
 getchar();
 return;
}
void search(Link l) /*图书查询*/
{
 int select;
 char searchinput[20];
 Node *p;
  if(!l->next) /*若链表为空*/
 {  
 system("cls");
  printf("\n=====>No record!\n");
   getchar();
  return;
}
  system("cls");
 printf("\n\t1 按书号查询 \n\t2 按书名查询\n");
  printf("      please choice[1,2,3]:");
  scanf("%d",&select);
 if(select==1)   /*按书号查询*/
  {
     stringinput(searchinput,10,"输入图书编号:"
);   
p=Locate(l,searchinput,"num");
   if(p) /*若p!=NULL*/  
 {   
 printheader();  
  printdata(p);
   printf("END");  
   printf("press any key to return");
   getchar();
   }
  else
   Nofind();
   getchar();
 }
 else if(select==2) /*按书名查询*/
{  
 stringinput(searchinput,15,"input the existing book name:");
  p=Locate(l,searchinput,"name");
if(p)
  {  
  printheader();  
  printdata(p);
   printf("END");
   printf("press any key to return");
   getchar();
  }   
else
   Nofind();
  getchar();  
}
 /*else if(select==3)//按借出次数排序  
{
     Disp(l);  
 getchar();
  }*/
 else  
 Wrong();
  getchar();
   }
void Del(Link l)/*删除指定的图书记录*/
{
 int sel;
  Node *p,*r;
 char findmess[20];
  if(!l->next)
 {
system("cls");
  printf("\n=====>No record!\n");
 getchar();
 return;
 }  
system("cls");
 Disp(l);
 printf("\n        =====>1 Delete by number       =====>2 Delete by name\n");
 printf("       please choice[1,2]:");
  scanf("%d",&sel);
  if(sel==1)  {   stringinput(findmess,10,"input the existing student number:");
 p=Locate(l,findmess,"num");
   if(p) /*p!=NULL*/
   {   
 r=l;   
 while(r->next!=p)
    r=r->next;
   r->next=p->next;/*将p所指节点从链表中去除*/  
  free(p); /*释放内存空间*/
   printf("\n=====>delete success!\n");  
  getchar();
   }
   else
Nofind();
  getchar();
  }
  else
 if(sel==2) /*先按书名查询*/
 {  
 stringinput(findmess,15,"input the existing book name");
   p=Locate(l,findmess,"name");
  if(p)  
 {
    r=l;  
  while(r->next!=p)  
   r=r->next;   
 r->next=p->next;  
  free(p);  
  printf("\n=====>delete success!\n");
   getchar();  
 }  
 else
 Nofind();  
 getchar();
 }
 else  
 Wrong();
  getchar();
 }
void Modify(Link l)/*修改图书信息*/
{
 Node *p;
 char findmess[20];
 if(!l->next)
 { system("cls");
 printf("\n=====>No book record!\n");
 getchar();
 return;
 }
 system("cls");
 printf("modify book recorder");
  Disp(l);
 stringinput(findmess,10,"input the existing book number:");
 p=Locate(l,findmess,"num"); /*查询到该节点*/  
if(p) /*若p!=NULL,表明已经找到该节点*/
{
  printf("Number:%s,\n",p->data.num);
  printf("Name:%s,",p->data.name);
   stringinput(p->data.name,15,"input book name:");
  printf("price:%d,",p->data.price);  
 p->data.price=numberinput("the price of book:");
  printf("Author:%s,",p->data.author);  
 stringinput(p->data.author,15,"Author:");
  printf("Publishing company:%s,",p->data.pub);  
 stringinput(p->data.pub,15,"Publishing company:");
  printf("number:%d,",p->data.number);  
 p->data.number=numberinput("the number of book:");
  printf("\n=====>modify success!\n");   
Disp(l);  
}
 else
  Nofind();  
getchar();
  }  
void Saveoi(Blink b)
 {  
FILE *fp;
 Bnode *p;
 int count=0;
  fp=fopen("f:\\borrow.txt","wb");/*以只写方式打开二进制文件*/
 if(fp==NULL) /*打开文件失败*/
 {
   printf("\n=====>open file error!\n");
  printf("\n=====>open file error!\n");
  getchar();
  return;   
}
 p=b->next;   
 while(p)
 {
  if(fwrite(p,sizeof(Bnode),1,fp)==1)/*每次写一条记录或一个节点信息至文件*/
  {
p=p->next;  
  count++;
  }  
 else  
 {  
  break;
  }
 }
  if(count>0)
  {  
 getchar();
  printf("\n\n\n\n\n=====>保存文件完成,本次保存的借书信息数量是:%d\n",count);
  getchar();  
}  
else  
{  
 system("cls");
   getchar();
 }  
fclose(fp);
 }
void borrow(Link l,Mlink m,Blink b)/*借书*/
{
  Mnode *p;  
Node *q;  
Bnode *t,*s,*k;
 char number[10],booknum[10];
 system("cls");
 t=b->next;   
  if(!t)
 {   
printf("\n=====>Not  record!\n");  
}
  printf("\n\n");
  printf(HEADER9);
  printf(HEADER7);
  printf(HEADER8);   
 while(t)
   {  
 printf(FORMAT2,t->binf.mnum,t->binf.mname,t->binf.num,t->binf.name);
  t=t->next;  
  printf(HEADER8);
  }
 while(1)
  {  
 s=b;
  p=m->next;  
 q=l->next;
  while(s->next!=NULL)
   s=s->next;
  stringinput(number,10,"输入会员号(输入0返回):");/*输入会员号*/
   if(strcmp(number,"0")==0)
    break;
  do
  {
   if(strcmp(p->inf.mnum,number)==0)/*查看该会员号是否存在*/  
   break;   
 else   
  p=p->next;
   }while(p!=NULL);
  stringinput(booknum,10,"输入图书编号:");/*输入书号*/
   do
  {
   if(strcmp(q->data.num,booknum)==0)/*查看书号是否存在*/  
   break;
   else  
   q=q->next;  
 }while(q!=NULL);   
  if(p==NULL)  
 {
   printf("你不是会员!");
   return;
  }  
else
 if(q==NULL)  
  {
     printf("图书编号错误!");
    return;
   }
   else
   {   
 if(q->data.number!=0)             /*如果图书剩余数量不为0,则图书数量-1,借出次数+1*/  
   {
q->data.number--;  
 q->data.bnumber++;  
  k=(Bnode *)malloc(sizeof(Bnode)); /*申请内存空间*/
    if(!k)
    {
     printf("\n allocate memory failure "); /*如没有申请到,输出提示信息*/
     return;              /*返回菜单界面*/
    }
    strcpy(k->binf.num,q->data.num);
    strcpy(k->binf.name,q->data.name);  
   strcpy(k->binf.mnum,p->inf.mnum);  
   strcpy(k->binf.mname,p->inf.mname);  
   k->next=NULL;  
    s->next=k; /*将新结点插入链表中*/  
   s=k;  
   }   
 else   
     printf("此书已借完!");
   }
 }  
Saveoi(b);/*写记录到磁盘文件中*/
 Save(l);
   }
void ret(Link l,Blink b)/*还书*/
 {  
Bnode *p,*q;
 Node *t;
 char memnum[10],booknum[10];
 q=b;
 p=q->next;
 t=l->next;
  system("cls");
  stringinput(memnum,10,"请输入会员号编号(输入0返回):");
  if(strcmp(memnum,"0")==0)
  return;
 stringinput(booknum,10,"请输入还书编号:");
 while(p!=NULL)  
{     
  if(strcmp(p->binf.num,booknum)==0&&strcmp(p->binf.mnum,memnum)==0)/*如果书号与会员号都存在则可以还书*/
   {   
q->next=p->next;  
  do   
 {  
   if(strcmp(t->data.num,booknum)==0)   
   break;   
  else  
    t=t->next;  
  }while(t!=NULL);
   t->data.number++;                       /*如果还书成功则可借的数目加1*/
   free(p);
   break;
  }  
 else
   {
   q=p;  
  p=q->next;
  }  
}  
if(p==NULL)
 {  
 printf("没有找到信息");
  getch();  
 return;
 }
  Saveoi(b);
  printf("删除数据成功,任意键返回");
 getch();  
 }
main()
{  
  Link l;     /*定义链表*/
 Mlink m;  
Blink b;
 FILE *fp;    /*文件指针*/
 int select;  
     char ch;  
     int count=0;  
 Node *p,*r;
   Mnode *q,*t;
 Bnode *s,*k;
 b=(Bnode*)malloc(sizeof(Bnode));
  if(!b)
 {
  printf("\n 分配内存失败 "); /*如没有申请到,打印提示信息*/
  return;              /*返回菜单界面*/
 }
 b->next=NULL;
 k=b;   
 fp=fopen("f:\\borrow.txt","ab+");
  if(fp==NULL)
  {  
 printf("\n=====>can not open file!\n");  
 exit(0);
  }   
 while(!feof(fp))
 {
  s=(Bnode*)malloc(sizeof(Bnode));
   if(!s)  
 {  
  printf(" memory malloc failure!\n");    /*没有申请成功*/  
  exit(0);       /*退出*/  
 }   
  if(fread(s,sizeof(Bnode),1,fp)==1) /*从文件中读取借书记录*/  
 {
  s->next=NULL;  
  k->next=s;
   k=s;
          }
  }
 fclose(fp); /*关闭文件*/
 m=(Mnode*)malloc(sizeof(Mnode));  
if(!m)
 {  
 printf("\n allocate memory failure "); /*如没有申请到,输出提示信息*/
  return;              /*返回菜单界面*/  
}
 m->next=NULL;
  t=m;   
 fp=fopen("f:\\member.txt","ab+");
  if(fp==NULL)
 {
  printf("\n=====>can not open file!\n");
  exit(0);
 }   
 while(!feof(fp))  
{  
 q=(Mnode*)malloc(sizeof(Mnode));
   if(!q)
   {
   printf(" memory malloc failure!\n");    /*没有申请成功*/
   exit(0);       /*退出*/
  }   
   if(fread(q,sizeof(Mnode),1,fp)==1) /*从文件中读取会员信息记录*/  
 {  
  q->next=NULL;  
  t->next=q;
    t=q;   
                         }
 }
 fclose(fp); /*关闭文件*/
 l=(Node*)malloc(sizeof(Node));  
if(!l)  
{
  printf("\n allocate memory failure "); /*如没有申请到,打印提示信息*/   
return;              /*返回菜单界面*/
  }
 l->next=NULL;
  r=l;
 fp=fopen("f:\\book.txt","ab+");
  if(fp==NULL)
 {  
 printf("\n=====>can not open file!\n");
  exit(0);
 }
 while(!feof(fp))
 {  
 p=(Node*)malloc(sizeof(Node));
  if(!p)
  {  
  printf(" memory malloc failure!\n");    /*没有申请成功*/   
 exit(0);       /*退出*/
  }   
if(fread(p,sizeof(Node),1,fp)==1) /*从文件中读取图书信息记录*/
  {  
  p->next=NULL;
   r->next=p;  
  r=p;   
    count++;
  }
 }   
 fclose(fp);
 printf("\n=====>文件打开成功,图书信息总数为 : %d.\n",count);
  menu();  
while(1)
 {   
system("cls");
  menu();
  p=r;
  printf("\n              请输入你的选择(0~9):");    /*显示提示信息*/
  scanf("%d",&select);
     switch(select)
  {  
 case 0:exit(1);
 case 1:Add(l);break;
 case 2:Del(l);break;
 case 3:search(l);break;
 case 4:Modify(l);break;
 case 5:Addmember(m);break;
 case 6:borrow(l,m,b);break;
 case 7:ret(l,b);break;
 case 8:searchbnum(l);break;
 case 9:Disp1(l);break;
 default: Wrong();getchar();break;
         }
  }
}
搜索更多相关主题的帖子: include member 出版社 会员 信息 
2015-05-28 22:44
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
收藏
得分:0 
标题就是答案:
'inf' : is not a member of 'node'

授人以渔,不授人以鱼。
2015-05-29 11:48
快速回复:'inf' : is not a member of 'node'
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.029857 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved