当前位置:首页 » 编程语言 » c语言如何借阅图书原理
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

c语言如何借阅图书原理

发布时间: 2022-12-13 21:06:34

⑴ 借同学百度知道问的,求一个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("入库成功.\n");
printf("已更改书库中该书的信息。编号 %s 的书 %s 作者是 %s ,出版社是 %s ,目前的总库存是 %d ,现库存是 %d 。\n",boo[mid].num,boo[mid].name,boo[mid].auth,boo[mid].pub,boo[mid].TotNum,boo[mid].NowNum);
}
if(!BinarySearch(boo,BuyNum))
{
for(int i=total;i>mid&&total;i--) //插在适合位置 保持有序
boo[i]=boo[i-1]; //空出插入位置

printf("该书在书库中不存在。设立新书目,请补全书的详细信息。\n");
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 。\n",boo[i].num,boo[i].name,boo[i].auth,boo[i].pub,boo[i].TotNum,boo[i].NowNum);
printf("入库成功.\n");
}
}

void Delete(ook &boo,char DeleteNum[])
{//2、 清空库存:某一种书已无保留价值,将它从图书账目中注销。

if(BinarySearch(boo,DeleteNum)==false||total==0) //如果无此书
printf("书库中没有该书.\n");
if(BinarySearch(boo,DeleteNum))//若有
{
if(!boo[mid].next)
{
for(int 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("已成功删除该书.\n");
}

else printf("该书有借阅者,无法删除。\n");

}
}

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("书库里没这书。\n");//如果有这书

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("借阅成功.\n");
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("借阅成功.\n");
}
}
else printf("借阅失败.该书现在库存为0.\n");
}
}

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("书库中无此书.\n");
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("成功归还该书.\n");
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("成功归还该书.\n");
flag=1;
break;
}
p=p->next;
}
}
}
}
for(int k=0;k<Retotal;k++)
if(!Lin[k].next)
{
for(int j=k;j<Retotal;j++)
Lin[j]=Lin[j+1]; //其后都往前移一位,覆盖掉当前信息
strcpy(Lin[j].CNum," "); //删除图书证号
Retotal--; //图书证数减1
} //删除当前状态下没借书的图书证的信息,节省空间
if(flag==0) printf("无该证信息.\n");
}

//5、 查找:实现按三种查询条件之一查找:按书号查找、
//按书名查找、按作者查找。注:可不实现组合查找,即几个条件组合查找。
void SearchByNum(ook &boo,char SeaNum[])
{//BY NUM 根据书号查找
LinkList *p;
p=boo[mid].next;
if(BinarySearch(boo,SeaNum)==false)printf("对不起,未找到您想查找的书。\n");//二分查找 没找到
else//找到了的话
{
{
printf("┏━━━━━━━┳━━━━━━━┳━━━━━━━━┳━━━━━━━━┳━━━━━┳━━━━━┓\n");
printf("┃ 书号 ┃ 书名 ┃ 作者 ┃ 出版社 ┃ 现库存 ┃ 总库存 ┃\n");
printf("┣━━━━━━━╋━━━━━━━╋━━━━━━━━╋━━━━━━━━╋━━━━━╋━━━━━┫\n");
printf("┃%14s┃%14s┃%16s┃%16s┃%10d┃%10d┃\n",boo[mid].num,boo[mid].name,boo[mid].auth,boo[mid].pub,boo[mid].NowNum,boo[mid].TotNum);
printf("┗━━━━━━━┻━━━━━━━┻━━━━━━━━┻━━━━━━━━┻━━━━━┻━━━━━┛\n");
if(boo[mid].next!=NULL)
{
printf("┏━━━━━━━┓\n");
printf("┃ 已借该书的 ┃\n");
printf("┃ 图书证号 ┃\n");
while(p)
{
printf("┣━━━━━━━┫\n");
printf("┃%14s┃\n",p->CardNum);
p=p->next;
}
printf("┗━━━━━━━┛\n");
}

}
while(p)
{
printf(" %s ",p->CardNum);//在按书号查找的函数里也显示借了这本书的借阅者的证号
p=p->next;
}
printf(" \n");
}//显示查找的书籍的信息
}

void SearchByName(ook &boo)
{//BY NAME 根据书名查找
char SeaName[20];
printf("输入想查找的书的书名:\n");
scanf(" %s",&SeaName);
printf("找到符合该书名的书的详细信息如下:\n");
for(int i=0;i<total;i++)
{
if(strcmp(SeaName,boo[i].name)==0)//如果书名一样
{
printf("书号:%s\n书名:%s\n作者:%s\n出版社:%s\n总库存量:%d\n现库存量:%d\n\n",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("输入想查找的书的作者:\n");
scanf(" %s",&SeaAuth);
printf("找到符合该作者的书的详细信息如下:\n");
for(int i=0;i<total;i++)
{
if(strcmp(SeaAuth,boo[i].auth)==0)//如果作者一样
{
printf("书号:%s\n书名:%s\n作者:%s\n出版社:%s\n总库存量:%d\n现库存量:%d\n\n",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("请输入您所想要查看的图书证号:\n");
scanf(" %s",&Num);
Bor *p;
int qqq=0;

for(int i=0;i<Retotal;i++)
{
if(strcmp(Lin[i].CNum,Num)==0) //找到该证
{
printf("这个证借的书有:\n");
p=Lin[i].next;
while(p)
{
printf(" %s ",p->BNum); //书号
p=p->next;
}
printf("\n");
qqq=1;
break;
}
}
if(qqq==0)
printf("该证不存在.\n");
}

void ViewBook(ook &boo,lend &Lin)
{//查看全部超期未还的图书
char date[8];
Bor *p;
printf("请输入日期(请按格式20060605输入):\n");
scanf(" %s",&date);
printf("所有超期未还的书有:\n");
for(int i=0;i<Retotal;i++)
{
p=Lin[i].next;
while(p)//当p不空时
{
if(strcmp(p->RetDate,date)<0) //超过日期
{
printf("书号为 %s 证号为 %s 应归还日期为 %s \n",p->BNum,Lin[i].CNum,p->RetDate);
}//显示所有超期未还的书的信息
p=p->next;
}
}
}

void Menu() //菜单
{
printf("┏—————————————————M E N U————————————————┓\n");
printf("│ │\n");
printf("│ 1. 采编入库:新购入一种书,如果该书在图书账目中已经存在, │\n");
printf("│ 则将其库存量增加(包括总库存量和现库存量)。 │\n");
printf("│ 如果该书不存在,则在图书账目中增加一种书, │\n");
printf("│ 总库存量和现库存量均为输入的数字。 │\n");
printf("│ 2. 清空库存:某一种书已无保留价值,将它从图书账目中注销。 │\n");
printf("│ 3. 借阅:如果一种书的现库存量大于零,则借出一本书,将现库存量减1, │\n");
printf("│ 并登记借阅者的图书证号和归还期限。 │\n");
printf("│ 4. 归还:注销对借阅者的登记,改变该书的现存量。 │\n");
printf("│ 5. 按书号查找。 │\n");
printf("│ 6. 按书名查找。 │\n");
printf("│ 7. 按作者查找。 │\n");
printf("│ 8. 查看某图书证号的借阅者借阅的全部图书。 │\n");
printf("│ 9. 查看全部超期未还的图书。 │\n");
printf("│ 0. 退出图书管理系统。 │\n");
printf("│ │\n");
printf("┗—————————————请 选 择 你 需 要 的 操 作————————————┛\n");
}

void main()
{
ook Bo;
lend Lin;
char BNum[20];
char CNum[20];
printf("-----------------------欢 迎 进 入 图 书 管 理 系 统!---------------------------\n\n");
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("请输入想要借阅的书的书号:\n");
scanf(" %s",&BNum);
printf("请输入图书证号:");
scanf(" %s",&CNum);
Borrow(Bo,Lin,BNum,CNum);
break;

case 4://归还
printf("请输入想要归还的书的书号:\n");
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("输入错误!\n");exit(0);break;

}
}
}

⑵ c语言图书借阅管理

像这种代码较多的,很少有人愿意写.

⑶ 用C语言编一个简单的图书管理系统(包括借阅查询还书三部分)(学生作业用)

#include<stdio.h>
#include<string.h>
struct sale/*商品名的定义*/
{int number;<br>char name[20];<br>float price;<br>long count;<br>long time;<br>long date;};

/*各个函数*/
void input(struct sale s[7]);/*输入函数*/
void output(struct sale s[7]);/*输出函数*/
void seek(struct sale s[7]);/*查找函数*/
void row(struct sale s[7]);/*排序函数*/
void change(struct sale s[7]);/*删除、修改、或插入*/

void main()/*主函数执行区域*/
{struct sale s[7]={{2,"pen",0.5,200,20050604,20090102},{1,"milk",3.5,100,20050403,20090202},
{5,"coke",3.5,500,20060203,20070503},{6,"chewing",0.3,200,20060305,20080205},
{4,"eraser",0.4,20,20060304,20500607},{3,"pencil",0.9,100,20040607,20060709}};/*定义初始值*/;
/*input(s);【已付初始值暂不运行!!】*/
output(s);
seek(s);
row(s);
change(s);
}

/*void input(struct sale s[7])【注释:已付初始值,暂不运行!!】
{int i;<br>printf("请分别输入产品编号、名称、单价、库存数量、入库时间、有效日期:\n");<br> for(i=0;i<7;i++)<br> scanf("%d%s%f%ld%ld%ld",&s.number,&s.name,&s.price,&s.count,&s.time,&s.date);}*/

void output(struct sale s[7])/*定义输出*/
{int i;<br>printf("编号\t名称\t单价\t库存数量\t入库时间\t\t有效日期\n");<br> for(i=0;i<7;i++)<br> printf("%d\t%s\t%.2f\t%ld\t\t%ld\t\t%ld\n",s.number,s.name,s.price,s.count,s.time,s.date);}

void seek(struct sale s[7])/*定义查找*/
{int i;<br> int m;<br> int k;<br> k=1;<br> printf("请输入要查找的编号\n");<br> printf("m== ");<br> scanf("%d",&m);<br> for(i=0;i<7;i++)<br> {<br> if(m==s.number)<br> {printf("你想查找的物品是:\n");<br> printf("编号\t名称\t单价\t库存数量\t入库时间\t\t有效日期\n");<br> printf("%d\t%s\t%.2f\t%ld\t\t%ld\t\t%ld\n",s.number,s.name,s.price,s.count,s.time,s.date);<br> k=m;}
}
if(k==1)
printf("没有此类商品!!!\n");
}

void row(struct sale s[7])/*排序*/
{
struct sale t;
int i,j;
int m,a;
printf("\n");
printf("输出已排好序的商品\n");
for(j=0;j<6;j++)
for(i=0;i<6-j;i++)

if(s.number>s.number)
{
t=s;
s=s;
s=t;
}
printf("重新排序后是; \n");
printf("编号\t名称\t单价\t库存数量\t入库时间\t\t有效日期\n");
for(a=0;a<7;a++)
printf("%d\t%s\t%.2f\t%ld\t\t%ld\t\t%ld\n",s[a].number,s[a].name,s[a].price,s[a].count,s[a].time,s[a].date);

}

void change(struct sale s[7])/*删除、修改、或插入*/
{
struct sale c;
int i,m,q,n,k;
k=0;
printf("请输入您要删除、修改或要插入的物品编号\n");/*前奏*/
scanf("%d",&m);
for(i=0;i<7;i++)
if(m==s.number)
{{printf("编号\t名称\t单价\t库存数量\t入库时间\t\t有效日期\n");<br> printf("%d\t%s\t%.2f\t%ld\t\t%ld\t\t%ld\n",s.number,s.name,s.price,s.count,s.time,s.date);}
printf("你确实要删除它么???还是要修改??\n");
printf("如果想删除请输入1,如果要修改请输入2。\n");
printf("您要输入的是: ");
scanf("%d",&q);
if(q==1)/*执行删除命令*/
{printf("您删除后的结果是:\n");<br> for(i=0;i<7;i++)<br> if(m!=s.number)<br> {printf("编号\t名称\t单价\t库存数量\t入库时间\t\t有效日期\n");<br> printf("%d\t%s\t%.2f\t%ld\t\t%ld\t\t%ld\n",s.number,s.name,s.price,s.count,s.time,s.date);}}
if(q==2)/*执行修改命令*/
{printf("输入你想修改的库存数量: ");<br> scanf("%d",&n);<br> s[m].count=n;<br> printf("修改后的商品信息为:\n");<br> printf("编号\t名称\t单价\t库存数量\t入库时间\t\t有效日期\n");<br> for(i=0;i<7;i++)<br> printf("%d\t%s\t%.2f\t%ld\t\t%ld\t\t%ld\n",s.number,s.name,s.price,s.count,s.time,s.date);}
k=i;
}

if(k==0)/*执行插入命令*/
{printf("\n\n");<br> printf("由于插入语句没有要求,所以插入语句尚未完成,有些功能尚未完善,所以会有错误,请老师见谅。\n\n\n");<br> printf("此类商品不存在,请插入\n");<br> printf("请分别输入要插入产品的编号、名称、单价、库存数量、入库时间、有效日期:\n");<br> i=m-1; <br> scanf("%d%s%f%ld%ld%ld",&s.number,&s.name,&s.price,&s.count,&s.time,&s.date);<br> printf("编号\t名称\t单价\t库存数量\t入库时间\t\t有效日期\n");<br> printf("%d\t%s\t%.2f\t%ld\t\t%ld\t\t%ld\n",s.number,s.name,s.price,s.count,s.time,s.date);<br> for(i=0;i<7;i++)<br> printf("%d\t%s\t%.2f\t%ld\t\t%ld\t\t%ld\n",s.number,s.name,s.price,s.count,s.time,s.date);<br> <br> <br> row(s);<br> <br> <br> }}
这是我大一时候做的大作业,虽然不是图书管理系统,你只要改改就行了,原理都一样,呵呵

⑷ c语言,模拟借书还书

//就说个大概吧,也没有太细节,简单的做法下面的代码就可以,当然可以做得更好更复杂,那就相当于是图书馆管理系统了。下面主要是借书、还书、查询是否到期等
#include<stdio.h>
#include<time.h>
#include<string.h>
#defineN5
#defineM5
typedefstruct{
intyear;
intmonth;
intday;
}Date;
typedefstruct{
charname[100];
charauthor[50];
intavailable;//是否可借(1可借,0不可外借)
Datedate;//入库/借出/还入日期
}Book;
typedefstruct{
intnumber;
charname[20];
intcount;//该生所持有的书数量
Bookbook[3];//每个学生最多只能同时保有3本书
}Student;
voidadd_book(Book*);//录入新书
intborrow_book(Book*,Student*);//借书
intreturn_book(Book*,Student*);
intquery(Book*,char*);//查询
Dateget_time();//获取当前时间
intcal_day(Date);//计算是否超期
voidmain()
{
Bookbook[N];
Studentstu[M];
charname[100];
inti;
//从文件中读入图书信息和学生信息
FILE*fp;
fp=fopen("d:\book.txt","r");
for(i=0;i<N&&!feof(fp);i++)
fscanf(fp,"%s%s%d%d%d%d",book[i].name,book[i].author,&book[i].available,&book[i].date.year,&book[i].date.month,&book[i].date.day);
fclose(fp);
fp=fopen("d:\student.txt","r");
for(i=0;i<M&&!feof(fp);i++)
{
fscanf(fp,"%d%s%d",&stu[i].number,stu[i].name,&stu[i].count);
for(intj=0;j<3;j++)
fscanf(fp,"%s%s%d%d%d%d",stu[i].book[j].name,stu[i].book[j].author,&stu[i].book[j].available,&stu[i].book[j].date.year,&stu[i].book[j].date.month,&stu[i].book[j].date.day);
}
fclose(fp);

intmode;
loop:
printf("1.录入图书 2.借书 3.还书 4.查询 *.退出 ");
scanf("%d",&mode);
switch(mode)
{
case1:
add_book(book);
break;
case2:
if(borrow_book(book,stu))printf("借书成功 ");
elseprintf("借书失败 ");
break;
case3:
if(return_book(book,stu))printf("还书成功 ");
elseprintf("还书失败 ");
break;
case4:
printf("输入书名:");
scanf("%s",name);
if(!query(book,name))printf("没有查询到该图书信息 ");
break;
default:
return;
}
gotoloop;
}
//根据学号,查看是否还能借入,如能借入更新借书的学生信息和图书信息
intborrow_book(Book*b,Student*s)
{
printf("输入书名:");
charname[100];
scanf("%s",name);
printf("输入学号:");
intnum;
scanf("%d",&num);
for(inti=0;i<M;i++)
if(s[i].number==num&&s[i].count<3)//持有数量3本以上无法借书
{
intc=s[i].count;
for(intj=0;j<N;j++)
if(strcmp(b[j].name,name)==0)//借书成功,更新信息
{
b[j].available=0;
b[j].date=get_time();
s[i].book[c]=b[j];
s[i].count=c+1;
return1;
}
}
return0;
}
//根据学号和书名查找到借书信息,并更新还书信息和计算是否超期
intreturn_book(Book*b,Student*s)
{
printf("输入书名:");
charname[100];
scanf("%s",name);
printf("输入学号:");
intnum;
scanf("%d",&num);
for(intj=0;j<M;j++)
if(s[j].number==num&&s[j].count>0)
{
for(intk=0;k<s[j].count;k++)
if(strcmp(s[j].book[k].name,name)==0)
{
s[j].count--;//更新学生持有书籍数量
for(inti=0;i<N;i++)
if(strcmp(b[i].name,name)==0)
{
if(query(b,name)>0)
printf("借书超期%d天,请交纳罚金 ");
b[i].available=1;
b[i].date=get_time();
return1;
}
}
}
return0;
}
voidadd_book(Book*book)
{
//录入新书并保存至文件
}
//根据书名查找图书信息,(还可以根据学生来查找,这里没实现)
intquery(Book*b,char*name)
{
for(inti=0;i<N;i++)
if(strcmp(b[i].name,name)==0)
{
if(b[i].available==1){printf("本书可以借出 ");return-1;}
else
{
intdays=cal_day(b[i].date);
printf("本书已被借出%d天 ",days);
if(days>10)
printf("本书已超期%d天 ",days-10);
returndays-10;
}
}
return0;
}
Dateget_time()
{
Datedate;
time_tcurtime;
structtm*timeinfo;
time(&curtime);//获取时间
timeinfo=localtime(&curtime);//转为当地时间
date.year=timeinfo->tm_year+1900;
date.month=timeinfo->tm_mon+1;
date.day=timeinfo->tm_mday;
returndate;
}
//计算借出的总天数
intcal_day(Dated)
{
Dateod=get_time();
if(od.year==d.year)
{
if(od.month==d.month)returnd.day-od.day;
elsereturnd.day-od.day+(od.month-d.month)*30;//每月按30天计
}
else
{return((d.month-1)*30+d.day)-((od.month-1)*30+od.day)+(d.year-od.year)*365;}//每年按365天计
}

以下是部分运行结果和书籍学生信息文本。


大概意思就是:多本书使用数组来保存,时间的计算用库函数。

⑸ 用C语言怎么设计图书借阅管理系统

首先要设计一个结构体存放借阅系统中包含的信息名,如书目,类型,数量等,然后设计主函数以制定系统的主界面或菜单界面,最后设计各种函数以实现你所设想的各种功能(函数名需要在编译预处理阶段设定,否则无法执行)。具体的例子我给不了,太长了,最少800多行呢!

⑹ 求人帮忙用C语言编写课程设计 图书借阅管理

给我个邮箱 发给你

⑺ C语言 图书管理系统 包括借书还书

在你的链表节点的结构体里面加一项,
int
count
就是借阅次数,然后累加计数。统计的时候就比较出来前10。 冒泡、快速随便你用。

⑻ C语言编程:图书借阅系统

没时间做了 实现不是很理想固定死了你这个实现 你可以在改下
/*1、 系统初始化10种图书(图书名自定);
2、 显示所有图书列表(编号、名称和当前状态);
3、 显示图书借出状态(是否已经被借阅);
4、 操作者可以通过图书名称进行查询,并借阅;
5、 操作者也可以归还某本已经借阅的图书;
6、 对某本图书的借阅次数进行汇总求和;
7、 求出借阅次数最多和最少的图书;*/
#ifndef LIBRARY_H
#define LIBRARY_H
#include<vector>
#include<string>
#include<iterator>
#include<utility>
#include<iostream>
using std::cin;
using std::vector;
using std::iterator;
using std::string;
using std::pair;
using std::istream;
class Book{
public:
Book(istream& i):ve(bo(i)){};//1、 系统初始化10种图书(图书名自定);
void list(size_t& n) const//查询
{ pair<string,bool> ir=ve[n+1];
std::cout<<"第"<<n<<"本书名"<<ir.first<<"状态"<<std::ends;
(ir.second==true)?std::cout<<"存在":std::cout<<"已借出"<<std::endl;
std::cout<<std::endl;}//2、 显示图书列表(编号、名称和当前状态);
void list(string& str) //查询并借阅
{
vector<pair<string,bool> >::iterator itr=ve.begin();
vector<pair<string,int> >::iterator it=pai.begin();
while(itr!=ve.end())
{if(itr->first==str&&it->first==str)
{std::cout<<"存在!请输入y/n确认是否借阅"<<std::ends;
char ch;cin>>ch;
if(ch=='y')
{itr->second=false;
it->second=it->second++;
std::cout<<"已借阅"<<std::ends;}
}else{std::cout<<"不存在"<<std::ends;}
++itr;++it;
}
}
void rest(string& str)
{vector<pair<string,bool> >::iterator itr=ve.begin();
while(itr++!=ve.end())
{if(itr->first==str&&itr->second==false)
{itr->second=true;
std::cout<<"已归还"<<" ";}else{std::cout<<"不在"<<std::endl;}}}//5、 操作者也可以归还某本已经借阅的图书;
void sum(const string str)
{vector<pair<string,int> >::iterator it=pai.begin();
int max=(++it)->second;
int min=(++it)->second;
string ma,mi;
while(it!=pai.end())
{
if(it->first==str)
{std::cout<<"借阅次数为"<<(it->second)<<std::ends;}
if(max<it->second)
{max=it->second;
ma=it->first;}
if(min>it->second)
{min=it->second;
mi=it->first;}}
std::cout<<"借阅最多次de 图书"<<ma<<" "<<max<<"次"<<std::endl;
std::cout<<"借阅最少次de 图书"<<mi<<" "<<min<<"次"<<std::endl;}/*6、 对某本图书的借阅次数进行汇总求和;
7、 求出借阅次数最多和最少的图书;*/
private:
vector<pair<string,bool> > bo(istream&);
vector<pair<string,bool> > ve;
vector<pair<string,int> > pai;
};

vector<pair<string,bool> > Book::bo(istream& is)//创建 图书 及存在情况
{
int i=0;
std::string s;
std::vector<pair<string,bool> > v;
vector<pair<string,int> > pai;
while(is>>s)
{
v.push_back(make_pair(s,true));
pai.push_back(make_pair(s,0));
++i;
if(i==10)
break;
}
is.clear();
return v;
}

#endif

下面是 main
#include<iostream>
#include"library.h"
using namespace std;
int main()
{
size_t x=5;
string str;
Book a(cin);//初始化
cin.clear();
a.list(x);//输入数字查询
cout<<"输入查询"<<endl;
cin>>str;
a.list(str);//输入字符查询并借阅
//a.rest(string("sa"));//归还
//a.sum(string("sa"));//查询某本书的借阅次数并统计输出借阅最多和最少的书
return 0;
}

⑼ c语言图书管理系统如何实现借书和还书功能