當前位置:首頁 » 編程語言 » 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語言圖書管理系統如何實現借書和還書功能