版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、課程設(shè)計說明書課程名稱: 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計班級:11電科1班姓名:張海琴學號:1111121132設(shè)計題目: 圖書管理系統(tǒng) 一、設(shè)計題目與要求【問題描述】設(shè)計一個計算機管理系統(tǒng)完成圖書管理基本業(yè)務(wù)。【基本要求】1) 每種書的登記內(nèi)容包括書號、書名、著作者、現(xiàn)存量和庫存量;2) 對書號建立索引表(線性表)以提高查找效率;3) 系統(tǒng)主要功能如下:采編入庫:新購一種書,確定書號后,登記到圖書帳目表中,如果表中已有,則只將庫存量增加;借閱:如果一種書的現(xiàn)存量大于0,則借出一本,登記借閱者的書證號和歸還期限,改變現(xiàn)存量;歸還:注銷對借閱者的登記,改變該書的現(xiàn)存量?!具M一步完成內(nèi)容】1) 系統(tǒng)功能的進一步
2、完善;2) 索引表采用樹表。3) 設(shè)計內(nèi)容4) 程序流程圖5) 源程序6) 軟件測試報告(包括所用到的數(shù)據(jù)及結(jié)果)二、概要設(shè)計有八個模塊1) 圖書初始化輸入圖書的一些信息,編號、作者、書名、數(shù)量,使有一定的庫存。2) 新書入庫新書采編入庫,輸入編號后如果有次數(shù)只需輸入數(shù)量,沒有則繼續(xù)輸入書名、作者、數(shù)量.3) 添加讀者信息讀者信息初始化,輸入讀書證號和姓名,只有輸入書證號和姓名才能進行借書還書4) 借書模塊讀者輸入讀書證號,證號存在輸入要借的圖書編號,不能借同一本書,如果借書數(shù)量以達到最大也不能借書。5) 還書模塊歸還已借的圖書,要先輸入讀者書證號,書證號存在繼續(xù)輸入要還的圖書編號,圖書編號存
3、在并且借來此書,歸還成功。6) 查詢圖書信息7) 查詢讀者信息可查詢讀者姓名書證號,借了幾本書,都是什么書和還書日期,還可以借幾本書。8) 退出退出讀書管理系統(tǒng)并保存讀者和圖書信息。圖書管理系統(tǒng)圖書管理模塊理讀者管理模塊借閱操作模塊查詢操作模塊借書系統(tǒng)讀者信息查詢圖書信息查詢輸入讀者信息還書系統(tǒng)采編入庫初始化圖書信息三、算法設(shè)計進入系統(tǒng)后首先進行圖書初始化,輸入圖書的信息。開始開始開始輸入圖書編號、名稱、作者和圖書數(shù)量進入系統(tǒng)初始化之后,進入系統(tǒng),顯示功能列表,可選擇任意系統(tǒng),但在借書之前先要輸入讀者信息。開始輸入功能所對應的數(shù)字輸入的數(shù)字小于0大于6錯誤!請重新輸入執(zhí)行所選功能1)采編入庫錄
4、入圖書信息判斷是否有此圖書是在原有的紀錄上加上現(xiàn)有的圖書數(shù)量否向系統(tǒng)中加入新紀錄2)輸入讀者信息開始輸入讀者信息:讀者書證號結(jié)束3)借閱圖書輸入讀者書證號判斷讀者是否存在否輸出次讀者編號不存在!按任意鍵返回是輸入要借的圖書編號判斷圖書編號是否存在否輸出此圖書編號不存在!按任意鍵返回是看是否還有此圖書否輸出此書已借完,按任意鍵返回是看讀者的借書數(shù)目是否滿了是輸出借書數(shù)目已滿不能借書,按任意鍵返回否看讀者是否借了相同的書是輸出同一讀者不能借相同的兩本書否輸入歸還圖書的日期圖書現(xiàn)有數(shù)量和庫存數(shù)量都減1輸出讀者結(jié)束成功,按任意鍵返回結(jié)束4)歸還圖書輸入要還書的讀者編號判斷讀者編號是否存在否輸出讀者編號
5、不存在按任意鍵返回是輸入讀者還書編號判斷圖書編號是否存在否輸出此圖書編號不存在按任意鍵返回是此圖書編號和還書日期等于0庫存和現(xiàn)有圖書數(shù)量加1,借書數(shù)量減1輸出讀者還書完畢,按任意鍵返回結(jié)束5)查詢圖書信息判斷圖書信息是否為空否輸出圖書信息:編號、名稱、作者、現(xiàn)有和庫存結(jié)束6)查詢讀者信息判斷讀者信息是否為空否輸出讀者書證號、姓名、圖書編碼和還書日期輸出讀者信息打印完畢結(jié)束四、運行結(jié)果和調(diào)試分析圖書信息初始化同一本新書入庫的運行結(jié)果圖不同的新書采編入庫采編入庫后查詢圖書信息的運行結(jié)果圖登記讀者信息借書借書后查詢圖書信息的運行結(jié)果圖借同一本書的運行結(jié)果圖借不同的書借兩本書后查詢讀者信息的運行結(jié)果圖
6、還書運行結(jié)果圖還書之后再查詢讀者信息的運行結(jié)果圖還書后查詢圖書信息退出五、總結(jié)體會雖然這次的程序是通過上網(wǎng)查出來的,但是通過這次的實驗使我知道了圖書管理系統(tǒng)的流程,知道了一些以前不知道的知識,在運行程序時也遇到了一些問題,借書時只能借一本書,再借書就不能顯示是借了還是不能借,把最多能借書的數(shù)量改了一下還是不行,最后在每一個判斷輸出之后都加了goto END借書,就能正常借書了。程序有點長,本來一個函數(shù)就能完成一個功能,他用了兩個函數(shù)就我把自己能改成一個的改了。借書系統(tǒng)比較復雜,不容易懂,和同學交流了一下自己看了看才明白。這次的實驗還讓我復習了數(shù)據(jù)結(jié)構(gòu)的一些知識,如數(shù)組,while語句,swit
7、ch語句,鏈表,還知道了如何使用system("cls”)清屏,還知道了strcmp是用來比較字符串s1和s2大小的,strcpy使用來把字符串s2的值賦給s1的。這次的實驗增加了我們自己動手動腦的能力,希望多做一些這樣的實驗,很有意義,和現(xiàn)實生活結(jié)合的程序增加了我的興趣。源代碼#includestdio。hinclude string。h#include stdlib.hinclude<conio。h#define Max 4 typedef struct bookchar book_num10;char book_name20;char book_writer10;int
8、book_xy;int book_kc;struct book next;BK;typedef struct borrowchar borrow_book_num10;char limit_date8;BO;typedef struct readerchar reader_num10;char reader_name10;int right;BO borrowMax;struct reader next;RD;BK *h_book;RD h_reader;void Login(); int Menu(); void Init(); void Init_book(); void Menu_sel
9、ect(); void Insert_New_Book(); void Find_Book(); void add_reader();void Print_reader(); void Print_book(); void Borrow_Book(); void Return_Book(); void Save(); void Save_Book(); void Save_Reader(); void Load();void Load_Reader(); void Load_Book(); void Login()system(”cls");printf("nnntt*n&
10、quot;);printf(”nnnttt歡迎使用圖書管理系統(tǒng)n");printf(”nnntt*n”);printf(”nntt本程序制作人 學號:nnnnnnn");printf(”nnntt 按任意鍵進入系統(tǒng)。.”);getch(); system(”cls”);int Menu() /主菜單/ int dm;printf(”ntt圖書管理系統(tǒng)主菜單n”);printf(”=n”);printf(”t0-退出系統(tǒng) n”);printf(”t1-采編入庫 n”);printf(”t2-登記讀者 n”); printf(”t3-借閱登記 n”);printf(”*t4-還
11、書管理 n”);printf("*t5-查詢圖書信息 n”);printf("t6-查詢讀者信息 n");printf(”=n");printf(”請選擇相應的代碼:"); for(;) scanf(”d",&dm); /dm輸入的數(shù)字 if(dm0|dm6) printf(”n錯誤!請重新輸入:”); else break;return dm; void Menu_select()/主菜單選擇函數(shù)/for(;) switch(Menu()) /功能選擇*/ case 0: system("cls"); S
12、ave();printf(”nnt文件保存成功!n”); printf(”nnt歡迎下次使用本系統(tǒng)!n”); getch(); exit(0); case 1:Insert_New_Book();break; case 2:add_reader();break; case 3:Borrow_Book();break; case 4:Return_Book();break; case 5:Print_book();break; case 6:Print_reader();break; default:printf("n錯誤!”); exit(0);void Init() /初始化/BK
13、 p0;printf("n圖書初始化開始,請輸入圖書信息.n包括編號.書名.數(shù)量。.n”);p0=(BK)malloc(sizeof(BK);h_book=p0; printf(”n請輸入圖書信息:n”); printf(”圖書編號:”); /輸入圖書編號(唯一)*/ scanf(”%s”,p0book_num); printf("圖書名稱:"); /*輸入圖書名稱/ scanf("%s”,p0-book_name);printf("圖書作者:”); /輸入圖書作者/ scanf("s”,p0book_writer); printf(
14、"圖書數(shù)量:”); /輸入圖書數(shù)量*/ scanf("%d",&p0book_kc); p0>book_xy=p0-book_kc; /開始時圖書現(xiàn)有量和庫存量相等*/ p0>next=NULL; printf("n圖書信息初始化完畢!按任意鍵繼續(xù)下一步操作.。n”); getch(); system(”cls");void Insert_New_Book()/新書入庫/BK p,p0,*p1; p=p1=h_book;printf(”n新書入庫模塊。n”);printf(”n請輸入新書信息。.n包括書號。書名.數(shù)量。n”)
15、;p0=(BK *)malloc(sizeof(BK); printf(”圖書編號:”); scanf("%s”,p0book_num); while(strcmp(p0->book_num,p1>book_num)!=0p1next!=NULL) p1=p1>next; if(strcmp(p0>book_num,p1>book_num)=0) /*此處分兩種情況,若圖書編號存在,則直接進庫,只須輸入書的數(shù)量/ printf(”n此編號圖書已存在!直接入庫!n"); printf(”圖書數(shù)量:"); scanf("d”,p
16、0>book_kc); p1->book_kc+=p0book_kc; p1>book_xy+=p0>book_kc; else/若不存在,則需要輸入其他的信息,然后在進行插入操作/ printf(”圖書名稱:"); scanf(”s",p0book_name);printf(”圖書作者:”); scanf(”s”,p0book_writer); printf(”圖書數(shù)量:”); scanf(”d",p0-book_kc);/庫存數(shù)量while(p>next) p=pnext; if(h_book=NULL) h_book=p0; /
17、此處分兩種情況,鏈表中沒有數(shù)據(jù),head直接指向p0處/ else p-next=p0; /此處分兩種情況,鏈表中有數(shù)據(jù),鏈表中最后元素的next指向p0處*/ p0>next=NULL; p0book_xy=p0book_kc; printf(”n新書入庫完畢!按任意鍵繼續(xù)下一步操作。.n”); getch(); system("cls”);void add_reader()/添加讀者/ RD *p0; int i; printf(”n讀者初始化開始,請輸入讀者信息。.n包括書證號。姓名。.n”);p0=(RD)malloc(sizeof(RD)); /申請新結(jié)點存儲空間/h
18、_reader=p0;printf(”n請輸入讀者的信息:n"); printf(”讀者書證號:”); scanf("%s”,p0-reader_num); printf(”讀者姓名:”); scanf(”%s”,p0reader_name); p0right=0; for(i=0;iMax;i+) strcpy(p0>borrowi.borrow_book_num,”0”); /所借圖書直接置為(即沒有借書)/ strcpy(p0>borrowi。limit_date,”0"); p0->next=NULL; printf(”n讀者信息初始化完
19、畢!按任意鍵繼續(xù)下一步操作.。n”); getch(); system(”cls”);void Borrow_Book() /借書模塊/BK p0; RD p1;char bo_num10,rea_num10,lim_date8;int i;p0=h_book; p1=h_reader;printf("n借書模塊。.。n");printf("n請輸入借書的讀者書證號:"); scanf("s",rea_num);while(p1-next!=NULLstrcmp(rea_num,p1>reader_num)!=0) p1=p1&
20、gt;next; if(p1next=NULL&strcmp(rea_num,p1>reader_num)!=0) printf(”n此讀者編號不存在!按任意鍵返回。.n”); goto END; printf(”n請輸入你要借的書的編號:”); scanf(”%s”,bo_num); while(strcmp(bo_num,p0>book_num)!=0&p0next!=NULL) p0=p0next; if(p0next=NULL&&strcmp(bo_num,p0book_num)!=0) printf(”n此圖書編號不存在!按任意鍵返回。n”
21、); goto END; else if(p0->book_xy<=0) printf(”n抱歉,此書已借完!請等待新書的到來!n按任意鍵返回.?!保? goto END; else if(p1->right>Maxp1right=Max) printf(”n不好意思,借書數(shù)目已滿!不能借書!n按任意鍵返回。.。"); goto END; else if(strcmp(p1borrow0.borrow_book_num,”0")!=0) for(i=0;i<Max;i+) if(strcmp(p1>borrowi。borrow_book_
22、num,bo_num)=0) printf(”n抱歉!同一個讀者不能同借兩本相同的書!n按任意鍵返回。.”); goto END; else if(strcmp(p1-borrowi.borrow_book_num,”0”)=0) printf(”n請輸入你要歸還圖書的日期:”); scanf(”s",lim_date); strcpy(p1>borrowp1right+。borrow_book_num,bo_num); strcpy(p1borrowp1right1。limit_date,lim_date); p0->book_xy-; p0book_kc-; prin
23、tf("n讀者編號%s借書完畢!按任意鍵繼續(xù)下步操作。",p1reader_num); goto END; else printf(”n請輸入你要歸還圖書的日期:”); scanf(”%s”,lim_date); strcpy(p1>borrowp1->right+。borrow_book_num,bo_num); strcpy(p1->borrowp1>right1。limit_date ,lim_date ); p0-book_xy-; p0->book_kc; printf(”n讀者編號%s借書完畢!按任意鍵繼續(xù)下步操作.?!保琾1rea
24、der_num); END:getch(); system("cls”); void Return_Book() /還書模塊/BK *p; RD q;int i,j,find=0;char return_book_num10,return_reader_num10;p=h_book; q=h_reader;printf("n還書模塊.。n”);printf(”n請輸入要還書的讀者編號:"); scanf("%s”,return_reader_num); while(q->next!=NULLstrcmp(return_reader_num,q-re
25、ader_num)!=0) q=q->next;if(q-next=NULLstrcmp(return_reader_num,qreader_num)!=0) find=2; printf("n此讀者編號不存在!按任意鍵返回。.n”); goto end; printf(”n請輸入讀者還書的編號:”); scanf(”s",return_book_num); while(p->next!=NULL&&strcmp(return_book_num,p->book_num)!=0) p=pnext; if(pnext=NULLstrcmp(re
26、turn_book_num,pbook_num)!=0) find=2; printf(”n錯誤!此圖書編號不存在!按任意鍵返回.。n”); goto end; for(i=0;i<Max;i+) if(strcmp(return_book_num,q->borrowi.borrow_book_num)=0) /如果此讀者借了此書*/ find=1; for(j=i;j<Max1;j+) strcpy(q-borrowj。borrow_book_num,q-borrowj+1.borrow_book_num); strcpy(q>borrowj。limit_date,q
27、-borrowj+1.limit_date); strcpy(q>borrowMax1.borrow_book_num,”0”); strcpy(q->borrowMax-1.limit_date,"0”); p->book_xy+; p>book_kc+; qright; printf(”n編號s的讀者還書完畢!按任意鍵繼續(xù)下步操作?!保瑀eturn_reader_num); if(find=0) printf("n錯誤!此讀者未借此書!按任意鍵返回。n”); end: getch(); system(”cls”);void Print_book(
28、) /*查詢圖書信息/BK *p;p=h_book;printf(”n圖書信息如下:nn");printf("圖書編號t圖書名稱t圖書作者t現(xiàn)有tt庫存n”);while(p!=NULL) printf(”stt%sttsttdttdn”,pbook_num,pbook_name,pbook_writer,p>book_xy,pbook_kc); p=p->next;printf(”n圖書信息打印完畢!按任意鍵繼續(xù)下一步操作。.”);getch();system(”cls");void Print_reader() /查詢讀者信息/RD p;int i
29、;p=h_reader;printf("n讀者信息如下:nn”);printf("讀者書證號tt讀者姓名n"); printf(”n”);while(p!=NULL) printf("tstts”,p>reader_num,p>reader_name); for(i=0;iMax;i+) printf(”n”); printf(”圖書編號”,i+1); printf(”t還書日期”,i+1); printf(”n”); printf("ts”,p>borrowi.borrow_book_num); printf("t
30、ts”,p>borrowi。limit_date); printf(”n”); p=p->next;printf("n讀者信息打印完畢!按任意鍵繼續(xù)下一步操作。");getch();system(”cls");void Save() /*保存信息/Save_Reader();Save_Book();void Save_Reader() /*保存讀者信息/FILE fp_reader; RD p,p0;p=h_reader;if(fp_reader=fopen(”Reader.txt”,"wb”)=NULL) /*創(chuàng)建文件,進行保存/ prin
31、tf(”n文件保存失??!n請重新啟動本系統(tǒng).。.n"); exit(0);while(p!=NULL) if(fwrite(p,sizeof(RD),1,fp_reader)!=1) /將鏈表中的信息寫入文件中*/ printf(”n寫入文件失??!n請重新啟動本系統(tǒng)!n"); p0=p; p=p-next; free(p0); /釋放所有結(jié)點*/h_reader=NULL;fclose(fp_reader); /關(guān)閉文件/void Save_Book() /保存圖書信息/FILE fp_book; /*創(chuàng)建文件型指針/BK p,p0;p=h_book;if((fp_book=fopen(”Book.txt”,”wb"))=NULL) /*創(chuàng)建文件,進行保存*/ printf("n文件保存失?。請重新啟動本系統(tǒng)。.。n"); exit(0);while(p!=NULL
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 城市基礎(chǔ)設(shè)施資產(chǎn)管理合同
- 醫(yī)療器械公司總裁招聘合同樣本
- 辦公區(qū)休閑區(qū)域施工合同模板
- 機場航站樓廊架施工合同
- 保安公司人事經(jīng)理聘用合同樣本
- 訂單履行與合同管理
- 航空物流總監(jiān)招聘合同樣本
- 體檢科護士招聘合同樣本
- 水利大壩建設(shè)級配碎石供應協(xié)議
- 2024美食節(jié)線上線下聯(lián)合營銷合作協(xié)議書3篇
- 《濟南聯(lián)通公司成本管理問題及解決策略7000字論文》
- 給志愿者培訓
- 191118-鋰離子電池專業(yè)術(shù)語英語對照大全
- 2024全新網(wǎng)絡(luò)與數(shù)據(jù)安全培訓
- 2023年貴州黔東南州州直機關(guān)遴選公務(wù)員筆試真題
- 心腦血管疾病預防課件
- DB35T 1036-2023 10kV及以下電力用戶業(yè)擴工程技術(shù)規(guī)范
- 中國移動自智網(wǎng)絡(luò)白皮書(2024) 強化自智網(wǎng)絡(luò)價值引領(lǐng)加速邁進L4級新階段
- 2024-2030年中國牛仔服裝行業(yè)市場深度調(diào)研及發(fā)展策略研究報告
- 數(shù)據(jù)中心災難恢復預案
- 《電氣檢測技術(shù)》教學大綱
評論
0/150
提交評論