c语言图书管理系统c语言图书管理系统
c语言图书管理系统  时间:2022-02-25  阅读:(
)
 
 
c语言图书管理系统
这不是按你这个要求的图书管理系统,不过你可以修改一下,你自己看下吧。  #include <stdio.h> #include <string.h> #include <stdlib.h> // #define MAXSIZE 100 //最大值定义为100 #define LIST_INIT_SIZE 100//图书证使用者最大值定义为100 //借书人的结构体  typedef struct Boro//借书行为 {  char BNum[20];//借书的书号  char RetDate[8];//归还日期  struct Boro *next; }Bor;  typedef struct LinkBook {  Bor *next;//该图书证的借书行为  char CNum[20];//证号  int Total;//借书的数量 }lend[LIST_INIT_SIZE];//借书人数组  //图书的结构体信息  typedef struct LNode {  char CardNum[20];//图书证号  struct LNode *next; }LinkList; //借书人  typedef struct book {//每种图书需要登记的内容包括书号ISBN、书名、作者、出版社、总库存量和现库存量。  char num[20];//书号  char name[20];//书名  char auth[20];//作者  char pub[20];//出版社  int TotNum;//总库存  int NowNum;//现库存  LinkList *next;//借了该书的人 }ook[MAXSIZE]; //  int Retotal;//读者数量 int total; //定义外部变量.书的种类数 // //结构体初始化 void InitBo(ook &boo) //初始化图书信息 {  for(int i=0;i<MAXSIZE;i++)  {  boo[i].NowNum=0;  boo[i].TotNum=0;  boo[i].next=NULL;  } }  void InitRe(lend &Lin) //初始化借阅者信息 {  for(int i=0;i<LIST_INIT_SIZE;i++)  Lin[i].next=NULL; }  //  int mid=0;//外部函数mid,用来返回查找到的位置  bool BinarySearch(ook boo,char SearchNum[]) //二分法查找比较书号 { //用bool函数,但由于函数不能有两个返回值,所以设置一个外部变量mid,用来返回查找到的位置  int low=0,high=total-1;  int found=0;  while(low<=high)  {  mid=(low+high)/2; //中间点  if(strcmp(boo[mid].num,SearchNum)==0) //书号相同  {  found=1;  return true;  }//查找成功  if(strcmp(boo[mid].num,SearchNum)!=0)//书号不同  high=mid-1;  else low=mid+1;  }  if(found==0)  return false; //查找失败 }  void Buy(ook &boo, char BuyNum[]) {//1、 采编入库:新购入一种书,如果该书在图书账目中已经存在,则将其库存量增加(包 //括总库存量和现库存量),如果该书不存在,则在图书账目中增加一种书,总库存量和现库存量均为1。  if(BinarySearch(boo,BuyNum)) //如果书库中有此书  {  boo[mid].TotNum++; //总库存加1  boo[mid].NowNum++; //现库存加1  printf("入库成功.
");  printf("已更改书库中该书的信息。编号 %s 的书 %s 作者是 %s ,出版社是 %s ,目前的总库存是 %d ,现库存是 %d 。
",boo[mid].num,boo[mid].name,boo[mid].auth,boo[mid].pub,boo[mid].TotNum,boo[mid].NowNum);  }  if(!BinarySearch(boo,BuyNum))  {  int i;  for(i=total;i>mid&&total;i--) //插在适合位置 保持有序  boo[i]=boo[i-1]; //空出插入位置   printf("该书在书库中不存在。设立新书目,请补全书的详细信息。
");  strcpy(boo[i].num,BuyNum);  printf("该书购入的数量是:");  scanf(" %d",&boo[i].NowNum);  boo[i].TotNum=boo[i].NowNum;  printf("该书的名字是:");  scanf(" %s",&boo[i].name);  printf("该书的作者是:");  scanf(" %s",&boo[i].auth);  printf("该书的出版社是:");  scanf(" %s",&boo[i].pub);//补全信息  boo[i].next=NULL;  total++;//总量+1  printf("已增加该书的信息。编号 %s 的书 %s 作者是 %s ,出版社是 %s ,目前的总库存是 %d ,现库存是 %d 。
",boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum);  printf("入库成功.
");  } }  void Delete(ook &boo,char DeleteNum[]) {//2、 清空库存:某一种书已无保留价值,将它从图书账目中注销。   if(BinarySearch(boo,DeleteNum)==false||total==0) //如果无此书  printf("书库中没有该书.
");  if(BinarySearch(boo,DeleteNum))//若有  {  if(!boo[mid].next)  {  int j;  for( j=mid;j<total;j++)  boo[j]=boo[j+1];   strcpy(boo[j].num,boo[j+1].num);  strcpy(boo[j].name,boo[j+1].name);  strcpy(boo[j].auth,boo[j+1].auth);  strcpy(boo[j].pub,boo[j+1].pub);  boo[j].TotNum=boo[j+1].TotNum;  boo[j].NowNum=boo[j+1].NowNum;  printf("已成功删除该书.
");  }   else printf("该书有借阅者,无法删除。
");   } }  void Borrow(ook &boo,lend &Lin,char BorrowNum[],char CaNum[]) {//3、 借阅:如果一种书的现库存量大于零,则借出一本书,将现库存量减1, //并登记借阅者的图书证号和归还期限。   Bor *p,*q;  LinkList *m,*n;  if(!BinarySearch(boo,BorrowNum)||total==0) //如果没有找到此书  printf("书库里没这书。
");//如果有这书   if(BinarySearch(boo,BorrowNum)) //书库里有  {  if(boo[mid].NowNum>0) //看现库存是否大于0  {  boo[mid].NowNum--;//借出一本,少1  if(boo[mid].next==NULL) //若该书信息下显示该种书还没被人借过  {  m=(LinkList *)malloc(sizeof(LNode));//分配  boo[mid].next=m;//该图书信息中的链表的第一个结点  strcpy(m->CardNum,CaNum);  m->next=NULL;//后一个结点为空  }  else //如果已经有人在借这书了  {  m=boo[mid].next;  while(m->next) //遍历到最后一个结点  m=m->next;  n=(LinkList *)malloc(sizeof(LNode));//分配空间,增加1个结点  m->next=n;  strcpy(n->CardNum,CaNum);//记录证号  n->next=NULL;  }  int i=0;  for(i=0;i<Retotal;i++)//  {  if(!strcmp(Lin[i].CNum,CaNum))//如果已经有该图书证的信息  {  p=Lin[i].next;  while(p->next)p=p->next;//遍历到最后一个结点  q=(Bor *)malloc(sizeof(Boro));//分配空间  p->next=q;  strcpy(q->BNum,BorrowNum); //记录书号  printf("输入归还日期:");  scanf("%s",&q->RetDate);  q->next=NULL;  printf("借阅成功.
");  break; //找到证了就跳出循环  }  }  if(i==Retotal)//如果没有这张证的信息  {  strcpy(Lin[i].CNum,CaNum); //记录证号  p=(Bor *)malloc(sizeof(Boro)); //分配空间  Lin[i].next=p;  strcpy(p->BNum,BorrowNum);  printf("输入归还日期:");  scanf(" %s",&p->RetDate);  p->next=NULL;  Retotal++; //借阅证号信息总数加1  printf("借阅成功.
");  }  }  else printf("借阅失败.该书现在库存为0.
");  } }  void Return(ook &boo,lend &Lin,char ReturnNum[],char BorrowerNum[]) {//4、 归还:注销对借阅者的登记,改变该书的现存量。  Bor *p,*q;  LinkList *m,*n;  int flag=0;//设置一个参数  if(!BinarySearch(boo,ReturnNum)||!total) //没书  printf("书库中无此书.
");  if(BinarySearch(boo,ReturnNum)) //有书  {  m=boo[mid].next;  if(!strcmp(m->CardNum,BorrowerNum)) //如果是第一个借的人还的  {  boo[mid].NowNum++; //现库存加1  boo[mid].next=m->next; //删除结点  free(m); //释放该结点的空间空间  }  else  {  while(m->next) //查找归还者的借阅者结点  {  if(!strcmp(m->next->CardNum,BorrowerNum)) //如果找到  {  n=m->next; //n为归还者的借阅结点  m->next=n->next; //m指向归还者的借阅结点的下一结点  free(n); //释放空间  boo[mid].NowNum++; //现库存加1  break;  }  m=m->next;  }  }  }  //在借阅者表里查找借阅者信息  for(int i=0;i<Retotal;i++)  {  if(!strcmp(Lin[i].CNum,BorrowerNum)) //如果找到借阅者  {  p=Lin[i].next;  if(!strcmp(p->BNum,ReturnNum)) //如果是归还的是借的第一本书  {  Lin[i].next=p->next; //指向下一借书结点  free(p); //释放结点空间  printf("成功归还该书.
");  flag=1;  break;  }  else //找不到  {  while(p->next) //找到归还书的借书结点  {  if(!strcmp(p->next->BNum,ReturnNum)) //如果找到  {  q=p->next; //q为归还书的借书结点  p->next=q->next; //p指向下一借书结点  free(q); //释放空间  printf("成功归还该书.
");  flag=1;  break;  }  p=p->next;  }  }  }  }  for(int k=0;k<Retotal;k++)  if(!Lin[k].next)  {  int j;  for(j=k;j<Retotal;j++)  Lin[j]=Lin[j+1]; //其后都往前移一位,覆盖掉当前信息  strcpy(Lin[j].CNum," "); //删除图书证号  Retotal--; //图书证数减1  } //删除当前状态下没借书的图书证的信息,节省空间  if(flag==0) printf("无该证信息.
"); }  //5、 查找:实现按三种查询条件之一查找:按书号查找、 //按书名查找、按作者查找。注:可不实现组合查找,即几个条件组合查找。 void SearchByNum(ook &boo,char SeaNum[]) {//BY NUM 根据书号查找  LinkList *p;  p=boo[mid].next;  if(BinarySearch(boo,SeaNum)==false)printf("对不起,未找到您想查找的书。
");//二分查找 没找到  else//找到了的话  {  {  printf("┏━━━━━━━┳━━━━━━━┳━━━━━━━━┳━━━━━━━━┳━━━━━┳━━━━━┓
");  printf("┃ 书号 ┃ 书名 ┃ 作者 ┃ 出版社 ┃ 现库存 ┃ 总库存 ┃
");  printf("┣━━━━━━━╋━━━━━━━╋━━━━━━━━╋━━━━━━━━╋━━━━━╋━━━━━┫
");  printf("┃%14s┃%14s┃%16s┃%16s┃%10d┃%10d┃
",boo[mid].num,boo[mid].name,boo[mid].auth,boo[mid].pub,boo[mid].NowNum,boo[mid].TotNum);  printf("┗━━━━━━━┻━━━━━━━┻━━━━━━━━┻━━━━━━━━┻━━━━━┻━━━━━┛
");  if(boo[mid].next!=NULL)  {  printf("┏━━━━━━━┓
");  printf("┃ 已借该书的 ┃
");  printf("┃ 图书证号 ┃
");  while(p)  {  printf("┣━━━━━━━┫
");  printf("┃%14s┃
",p->CardNum);  p=p->next;  }  printf("┗━━━━━━━┛
");  }   }  while(p)  {  printf(" %s ",p->CardNum);//在按书号查找的函数里也显示借了这本书的借阅者的证号  p=p->next;  }  printf(" 
");  }//显示查找的书籍的信息 }  void SearchByName(ook &boo) {//BY NAME 根据书名查找  char SeaName[20];  printf("输入想查找的书的书名:
");  scanf(" %s",&SeaName);  printf("找到符合该书名的书的详细信息如下:
");  for(int i=0;i<total;i++)  {  if(strcmp(SeaName,boo[i].name)==0)//如果书名一样  {  printf("书号:%s
书名:%s
作者:%s
出版社:%s
总库存量:%d
现库存量:%d
",boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum);  }//显示符合信息的所有书籍的信息  } }  void SearchByAuth(ook &boo) {// BY AUTH 根据作者查找  char SeaAuth[20];  printf("输入想查找的书的作者:
");  scanf(" %s",&SeaAuth);  printf("找到符合该作者的书的详细信息如下:
");  for(int i=0;i<total;i++)  {  if(strcmp(SeaAuth,boo[i].auth)==0)//如果作者一样  {  printf("书号:%s
书名:%s
作者:%s
出版社:%s
总库存量:%d
现库存量:%d
",boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum);  }//显示符合信息的所有书籍的信息  } }  //6、 查看:可查看某图书证号的借阅者借阅的全部图书,可查看全部超期未还的图书。  void ViewCard(ook &boo,lend &Lin) {//查看某图书证号的借阅者借阅的全部图书  char Num[20];  printf("请输入您所想要查看的图书证号:
");  scanf(" %s",&Num);  Bor *p;  int qqq=0;   for(int i=0;i<Retotal;i++)  {  if(strcmp(Lin[i].CNum,Num)==0) //找到该证  {  printf("这个证借的书有:
");  p=Lin[i].next;  while(p)  {  printf(" %s ",p->BNum); //书号  p=p->next;  }  printf("
");  qqq=1;  break;  }  }  if(qqq==0)  printf("该证不存在.
"); }  void ViewBook(ook &boo,lend &Lin) {//查看全部超期未还的图书  char date[8];  Bor *p;  printf("请输入日期(请按格式20060605输入):
");  scanf(" %s",&date);  printf("所有超期未还的书有:
");  for(int i=0;i<Retotal;i++)  {  p=Lin[i].next;  while(p)//当p不空时  {  if(strcmp(p->RetDate,date)<0) //超过日期  {  printf("书号为 %s 证号为 %s 应归还日期为 %s 
",p->BNum,Lin[i].CNum,p->RetDate);  }//显示所有超期未还的书的信息  p=p->next;  }  } }  void Menu() //菜单 {  printf("┏—————————————————M E N U————————————————┓
");  printf("│ │
");  printf("│ 1. 采编入库:新购入一种书,如果该书在图书账目中已经存在, │
");  printf("│ 则将其库存量增加(包括总库存量和现库存量)。 │
");  printf("│ 如果该书不存在,则在图书账目中增加一种书, │
");  printf("│ 总库存量和现库存量均为输入的数字。 │
");  printf("│ 2. 清空库存:某一种书已无保留价值,将它从图书账目中注销。 │
");  printf("│ 3. 借阅:如果一种书的现库存量大于零,则借出一本书,将现库存量减1, │
");  printf("│ 并登记借阅者的图书证号和归还期限。 │
");  printf("│ 4. 归还:注销对借阅者的登记,改变该书的现存量。 │
");  printf("│ 5. 按书号查找。 │
");  printf("│ 6. 按书名查找。 │
");  printf("│ 7. 按作者查找。 │
");  printf("│ 8. 查看某图书证号的借阅者借阅的全部图书。 │
");  printf("│ 9. 查看全部超期未还的图书。 │
");  printf("│ 0. 退出图书管理系统。 │
");  printf("│ │
");  printf("┗—————————————请 选 择 你 需 要 的 操 作————————————┛
"); }  void main() {  ook Bo;  lend Lin;  char BNum[20];  char CNum[20];  printf("-----------------------欢 迎 进 入 图 书 管 理 系 统!---------------------------
");  int choice=10;  int SearchCho=10,ViewCho=10;  while(choice!=0)  {  Menu();//显示菜单  scanf(" %d",&choice);  switch(choice)  {  case 1://采编入库  printf("请输入入库的书的书号:");  scanf(" %s",BNum);  Buy(Bo,BNum);  break;   case 2://清空库存  printf("请输入想要清除的书的书号:");  scanf(" %s",BNum);  Delete(Bo,BNum);  break;   case 3://借阅  printf("请输入想要借阅的书的书号:
");  scanf(" %s",&BNum);  printf("请输入图书证号:");  scanf(" %s",&CNum);  Borrow(Bo,Lin,BNum,CNum);  break;   case 4://归还  printf("请输入想要归还的书的书号:
");  scanf(" %s",&BNum);  printf("请输入图书证号:");  scanf(" %s",&CNum);  Return(Bo,Lin,BNum,CNum);  break;   case 5://查找//根据书号查找  printf("请输入书号:");//输入书号查找  scanf(" %s",&BNum);  SearchByNum(Bo,BNum);  break;   case 6://根据书名查找  SearchByName(Bo);  break;   case 7://根据作者查找  SearchByAuth(Bo);  break;   case 8://查看某图书证所借的所有书  ViewCard(Bo,Lin);  break;   case 9: //查看全部超期未还的书  ViewBook(Bo,Lin);  break;   case 0://退出系统  exit(0);break;   default:printf("输入错误!
");exit(0);break;   }  } } 
		  
		  
		      
			  
		  
			  			   
			      
			        
			          
			          Pia云商家在前面有介绍过一次,根据市面上的信息是2018的开办的国人商家,原名叫哔哔云,目前整合到了魔方云平台。这个云服务商家主要销售云服务器VPS主机业务和服务,云服务器采用KVM虚拟架构 。目前涉及的机房有美国洛杉矶、中国香港和深圳地区。洛杉矶为crea机房,三网回程CN2 GIA,自带20G防御。中国香港机房的线路也是CN2直连大陆,比较适合建站或者有游戏业务需求的用户群。在这篇文章中,简...
			         
			       
				  
			     
							   
			      
			        
			          
			          WHloud Official Notice(鲸云官方通知)(鲸落 梦之终章)]WHloud RouMu Cloud Hosting若木产品线云主机-香港节点上新预售本次线路均为电信CN2 GIA+移动联通BGP,此机型为正常常规机,建站推荐。本次预售定为国庆后开通,据销售状况决定,照以往经验或有咕咕的可能性,但是大多等待时间不长。均赠送2个快照 2个备份,1个默认ipv4官方网站:https:/...
			         
			       
				  
			     
							   
			      
			        
			          
			          搬瓦工怎么样?这几天收到搬瓦工发来的邮件,告知香港pccw机房(HKHK_1)即将关闭,这也不算是什么出乎意料的事情,反而他不关闭我倒觉得奇怪。因为目前搬瓦工香港cn2 GIA 机房和香港pccw机房价格、配置都一样,可以互相迁移,但是不管是速度还是延迟还是丢包率,搬瓦工香港PCCW机房都比不上香港cn2 gia 机房,所以不知道香港 PCCW 机房存在还有什么意义?关闭也是理所当然的事情。点击进...
			         
			       
				  
			     
							
			   
			   
c语言图书管理系统为你推荐
	诺诺云代账诺诺云代账有什么优势?论坛源码求高手推荐一个好的论坛源码?要可以购买版权的那种,要便宜的溢出隐藏overflow:hidden是什么意思?oracle索引oracle表加索引有什么用? 请举一个例子说明谢谢拓扑关系什么是矢量数据、栅格数据、拓扑关系?layout_gravityandroid 布局中 为什么能够通过android:layout_above 、android:layout_alignTop 、等 还要在之前加入jql建筑设计图纸上JQL 梁,是不是地下正负零基础梁?急急!smartuploadjspsmartupload如何使用?smartupload为什么使用smartupload执行上传保存操作时用这句smart.save("upload")失败用smart.save("/upload")成功smartupload使用SmartUpload实现文件上传时需要对表单设置哪些属性
最好的虚拟主机 日本动态vps 便宜建站 tk域名 好看的桌面背景图 ev证书 网站被封 日本空间 dd444 台湾谷歌地址 国外代理服务器软件 isp服务商 服务器硬件防火墙 东莞服务器托管 supercache 中国联通宽带测试 服务器防御 linux服务器系统 流媒体服务器软件 kosspp 更多