版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、<p> 課 程 設(shè) 計(jì) 報(bào) 告</p><p> 課程設(shè)計(jì)名稱:數(shù)據(jù)結(jié)構(gòu) </p><p> 系 : </p><p> 學(xué)生姓名: </p><p> 班 級: </p><p> 學(xué) 號:
2、 </p><p> 成 績: </p><p> 指導(dǎo)教師: </p><p> 開課時間: 2011-2012 學(xué)年 1 學(xué)期</p><p><b> 一.設(shè)計(jì)題目</b></p><p><b> 圖書管
3、理系統(tǒng)</b></p><p><b> 二.主要內(nèi)容</b></p><p> 圖書管理系統(tǒng)的設(shè)計(jì)主要是實(shí)現(xiàn)對圖書的管理和相關(guān)操作?;竟δ苋缦拢?lt;/p><p> ?。?)圖書信息錄入、添加功能:包括書號、書名、作者、出版社名稱、存館數(shù)量、定價等。</p><p> ?。?)圖書信息查詢功能:可以按書
4、名, 按作者名, 按出版單位等進(jìn)行查詢。</p><p> ?。?)排序:按書號、書名等按升序進(jìn)行排序。</p><p> ?。?)圖書的修改、刪除功能:按書號或書名進(jìn)行圖書的修改和刪除。</p><p> (5)圖書借閱、歸還功能:如果一種書的現(xiàn)存量大于0,可以借出,借出相應(yīng)數(shù)量后改變現(xiàn)存量;歸還時改變該書的現(xiàn)存量。</p><p>
5、三.課題設(shè)計(jì)的基本思想,原理和算法描述</p><p><b> ?。ㄒ唬┗舅枷耄?lt;/b></p><p> 所用數(shù)據(jù)結(jié)構(gòu):線性表、查找、排序</p><p> 設(shè)計(jì)方案圖形表示如下面圖形所示:</p><p><b> (二)原理:</b></p><p> 圖書
6、管理系統(tǒng)要求實(shí)現(xiàn)許多的功能。將軟件的設(shè)計(jì)任務(wù)分成許多小的功能模塊進(jìn)行設(shè)計(jì)。本程序經(jīng)過分析分成以下幾個子任務(wù):圖書信息錄入、圖書信息的查詢、圖書信息的排序、圖書信息的修改、圖書信息的刪除、圖書的借閱、圖書的歸還、退出圖書管理系統(tǒng)。</p><p> (三)具體函數(shù)的算法描述:</p><p><b> 1.主函數(shù)</b></p><p>
7、void main() //主函數(shù)</p><p><b> {</b></p><p><b> int s;</b></p><p> LinkList *L;</p><p> L=(LinkList *)malloc(sizeof(LinkList)); </p&
8、gt;<p> InitList(*&L);</p><p> w:while(s!=0)</p><p><b> {</b></p><p> printf("------------------------------------------------------------------- \n
9、");</p><p> printf(" 歡迎光臨圖書管理系統(tǒng)! \n");</p><p> printf("------------------------------------------------------------------- \n
10、");</p><p> printf("1.圖書信息錄入添加功能:\n");</p><p> printf("2.圖書信息查詢功能:\n"); </p><p> printf("3.圖書信息排序功能:\n");</p><p> printf("4.
11、圖書的修改功能:\n");</p><p> printf("5.圖書的刪除功能:\n");</p><p> printf("6.圖書借閱功能:\n");</p><p> printf("7.圖書歸還功能:\n");</p><p> printf("
12、0.退出系統(tǒng):\n");</p><p> printf("請選擇你需要的操作:\n");</p><p> scanf("%d",&s);</p><p><b> switch(s)</b></p><p><b> {</b>&
13、lt;/p><p> case 1: CreateListR(L);break;</p><p> case 2: LocateElem(L);break;</p><p> case 3: Sort(L);Display(L);break;</p><p> case 4: ModifyList(L);break;</p>
14、<p> case 5:ListDelete(L); break;</p><p> case 6:Borrow(L); break;</p><p> case 7:Return(L); break;</p><p> case 0:printf("謝謝使用\n");return 0;break;goto w;}<
15、/p><p><b> }</b></p><p><b> }</b></p><p> 2.圖書信息錄入添加功能:</p><p> int CreateListR(LinkList *&L) //尾插法建表</p><p> { int
16、i,n; </p><p> LinkList *s,*q,*p;</p><p><b> p=L;</b></p><p> while(p->next!=NULL)</p><p> p=p->next;</p><p> printf("請輸入需要錄入的圖書
17、信息的個數(shù):n=");</p><p> scanf("%d",&n);</p><p> for(i=1;i<n+1;i++)</p><p><b> { </b></p><p> s=(LinkList *)malloc(sizeof(LinkList));&l
18、t;/p><p> printf("書號 書名 作者 出版社名稱 存館數(shù)量 定價\n");</p><p> scanf("%d%s%s%s%d%s",&s->data.num,s->data.name,s->data.author,s->data.press,&s->data.coun
19、t,s->data.price);</p><p> q=L->next;</p><p> if(q==NULL)</p><p><b> {</b></p><p> p->next=s; </p><p><b> p=s;</b><
20、/p><p> p->next=NULL;</p><p> printf("錄入成功!\n");</p><p><b> continue;</b></p><p><b> }</b></p><p> while(q!=NULL)<
21、;/p><p><b> {</b></p><p> if(strcmp(s->data.name,q->data.name)==0)</p><p> { printf("此圖書已存在!");</p><p> printf("請重新輸入:");</
22、p><p> scanf("%d%s%s%s%d%s",&p->data.num,p->data.name,p->data.author,p->data.press,&p->data.count,p->data.price);</p><p><b> }</b></p><p
23、> q=q->next;</p><p><b> }</b></p><p> p->next=s; </p><p><b> p=s;</b></p><p> p->next=NULL;</p>
24、<p> printf("錄入成功!\n");</p><p><b> } </b></p><p><b> return 0;</b></p><p><b> }</b></p><p> 3.圖書信息查詢功能:</p&
25、gt;<p> void LocateElem(LinkList *&L) //查詢 </p><p><b> {</b></p><p> LinkList *p=L->next; //p指向第一個數(shù)據(jù)結(jié)點(diǎn)</p><p><b>
26、int c;</b></p><p><b> int x=0;</b></p><p> char name1[10],author1[10],press1[10];</p><p> printf(" 1 按書名查詢:\n");</p><p> printf("
27、 2 按作者名查詢:\n");</p><p> printf(" 3 按出版社名稱:\n");</p><p> printf(" 4 返回\n");</p><p> printf(" 請選擇1--4進(jìn)行操作:\n"); </p><p>
28、; scanf("%d",&c);</p><p> if(c>4||c<1)</p><p><b> {</b></p><p> printf("您的輸入有誤!\n");</p><p> scanf("%d",&c)
29、;</p><p><b> }</b></p><p><b> switch(c)</b></p><p><b> {</b></p><p> case 1:printf("請輸入圖書書名: \n");</p><p>
30、; scanf("%s",&name1);</p><p> while(p!=NULL)</p><p><b> {</b></p><p> if(strcmp( name1,p->data.name)!=0)//查找圖書書名</p><p> p=p->next;
31、 </p><p><b> else</b></p><p><b> {</b></p><p> printf("書號 書名 作者 出版社名稱 存館數(shù)量 定價\n");</p><p> printf("%d %s %s
32、 %s %d %s",p->data.num,p->data.name,p->data.author,p->data.press,p->data.count,&p->data.price);</p><p> printf("\n");</p><p> p=p->next;
33、</p><p><b> x++;</b></p><p><b> }</b></p><p><b> } </b></p><p> if (p==NULL&&x==0)</p><p> printf("對
34、不起,不存在此圖書!\n");</p><p><b> ;break;</b></p><p> case 2:printf("請輸入圖書作者:\n");</p><p> scanf("%s",author1);</p><p> while(p!=NULL)
35、</p><p><b> {</b></p><p> if(strcmp( author1,p->data.author)!=0)//查找圖書作者 </p><p> p=p->next; </p><p><b> else</b></p><p>
36、;<b> {</b></p><p> printf("書號 書名 作者 出版社名稱 存館數(shù)量 定價\n");</p><p> printf("%d %s %s %s %d %s",p->data.num,p->data.name,p->
37、;data.author,p->data.press,p->data.count,&p->data.price);</p><p> printf("\n");</p><p> p=p->next ;</p><p><b> x++;</b></p><p>
38、;<b> }</b></p><p><b> } </b></p><p> if (p==NULL&&x==0)</p><p> printf("對不起,不存在此圖書!\n");</p><p><b> ;break;</b
39、></p><p> case 3:printf("請輸入圖書的出版社名稱: \n"); </p><p> scanf("%s",press1);</p><p> while(p!=NULL)</p><p><b> {</b></p>&l
40、t;p> if(strcmp( press1,p->data.press)!=0)//查找圖書出版社名稱 </p><p> p=p->next; </p><p><b> else</b></p><p><b> {</b></p><p> printf(&q
41、uot;書號 書名 作者 出版社名稱 存館數(shù)量 定價\n");</p><p> printf("%d %s %s %s %d %s",p->data.num,p->data.name,p->data.author,p->data.press,p->data.count,&p-&
42、gt;data.price);</p><p> printf("\n");</p><p> p=p->next;</p><p><b> x++;</b></p><p><b> }</b></p><p><b> }
43、</b></p><p> if (p==NULL&&x==0)</p><p> printf("對不起!不存在此圖書\n");</p><p><b> ;break;</b></p><p><b> case 4:</b></p
44、><p><b> break;</b></p><p><b> }</b></p><p><b> }</b></p><p> 4.圖書信息排序功能:</p><p> int Sort(LinkList *&L) //遞增
45、有序排序(直接插入排序法)</p><p><b> {</b></p><p> LinkList *p=L->next,*q,*r; //p指向第一個數(shù)據(jù)結(jié)點(diǎn)</p><p> if(p!=NULL) //若原單鏈表中有一個或以上的數(shù)據(jù)結(jié)點(diǎn)</p><p><b>
46、 {</b></p><p> r=p->next; //r保存*p結(jié)點(diǎn)直接后繼結(jié)點(diǎn)的指針</p><p> p->next=NULL; //構(gòu)造只含一個數(shù)據(jù)結(jié)點(diǎn)的有序表</p><p><b> p=r;</b></p><p> while(p!
47、=NULL)</p><p><b> {</b></p><p> r=p->next; //r保存*p結(jié)點(diǎn)的直接后繼結(jié)點(diǎn)的指針</p><p><b> q=L;</b></p><p> while(q->next!=NULL&&q->n
48、ext->data.num<p->data.num)</p><p> q=q->next; //在有序表中找插入*p的直接前驅(qū)結(jié)點(diǎn)*q的位置</p><p> p->next=q->next; //將*p插入到*q之后</p><p> q->next=p;</p><p> p=r
49、; //掃描原單鏈表余下的結(jié)點(diǎn)</p><p><b> }</b></p><p><b> }</b></p><p><b> return 0;</b></p><p><b> }</b></p>
50、<p> void Display(LinkList *&L) //輸出排序結(jié)果</p><p><b> {</b></p><p> LinkList *p=L->next;</p><p> while (p!=NULL)</p><p><b> {</b&g
51、t;</p><p> printf("書號 書名 作者 出版社名稱 存館數(shù)量 定價\n");</p><p> printf("%d %s %s %s %d %s",p->data.num,p->data.name,p->data.author,p->data.press
52、,p->data.count,p->data.price);</p><p> printf("\n");</p><p> p=p->next;</p><p><b> }</b></p><p><b> }</b></p><
53、p> 5. 圖書信息的修改功能:</p><p> ModifyList(LinkList *&L) //修改</p><p> { </p><p> LinkList *p=L;</p><p> char name1[10];</p><p&g
54、t; printf("請輸入要修改的圖書的書名:\n");</p><p> scanf("%s",name1);</p><p> while(p!=NULL)</p><p><b> {</b></p><p> if(strcmp(name1,p->data
55、.name)==0) //查找所要修改的書名</p><p><b> { </b></p><p> printf("請輸入修改后的信息!\n");</p><p> printf("書號 書名 作者 出版社名稱 存館數(shù)量 定價\n");</p><p>
56、; scanf("%d%s%s%s%d%s",&p->data.num,p->data.name,p->data.author,p->data.press,&p->data.count,p->data.price);</p><p> printf("修改成功!\n"); </p><p>&
57、lt;b> return 0;</b></p><p><b> }</b></p><p> p=p->next;</p><p><b> }</b></p><p> printf("不存在此圖書\n");</p><p
58、><b> return 0;</b></p><p><b> }</b></p><p> 6.圖書信息的刪除功能:</p><p> int ListDelete(LinkList *&L) //刪除 </p><p> { LinkList
59、 *p=L->next,*q=L;</p><p> char name1[10];</p><p> if(p!=NULL)</p><p><b> {</b></p><p> printf("請輸入要刪除的書名:");</p><p> scanf(&q
60、uot;%s",&name1);</p><p><b> }</b></p><p> while(p->next!=NULL&&strcmp(p->data.name,name1)!=0)</p><p><b> {</b></p><p>
61、 p=p->next;</p><p> q=q->next;</p><p><b> }</b></p><p> if(p->next!=NULL) //如果p此時不是最后一個節(jié)點(diǎn),說明此時已經(jīng)找到書</p><p><b> {</b></p>
62、<p> q->next=p->next;</p><p> printf("刪除成功!\n");</p><p><b> return 0;</b></p><p><b> }</b></p><p> if(p->next==NULL
63、&&strcmp(name1,p->data.name)!=0) //如果p此時為最后一個結(jié)點(diǎn)并且沒有找到與之相符的書名</p><p><b> {</b></p><p> printf("你輸入的書名不存在,請核實(shí)后重新輸入!\n");</p><p><b> } </b
64、></p><p><b> else</b></p><p><b> {</b></p><p> q->next=NULL;</p><p> printf("刪除成功!\n");</p><p><b> }<
65、/b></p><p><b> return 0;</b></p><p><b> }</b></p><p> 7.圖書的借閱功能:</p><p> void Borrow(LinkList *&L) //借閱</p><p><b&
66、gt; {</b></p><p> LinkList *p=L->next;</p><p> char name1[10];</p><p> printf("請輸入要借閱的圖書的書名:\n");</p><p> scanf("%s",&name1);</
67、p><p> while(p->next!=NULL&&strcmp(name1,p->data.name)!=0)</p><p> p=p->next;</p><p> if(p->next==NULL&&strcmp(name1,p->data.name)!=0)</p><
68、p> printf("此圖書不存在!");</p><p> else if(p->data.count<1) </p><p> printf("此書已借完!\n") ;</p><p> else if(strcmp(name1,p->data.name)==0)</p>
69、<p><b> {</b></p><p> printf("借書成功!\n");</p><p> p->data.count--;</p><p><b> } </b></p><p><b> }</b><
70、/p><p> 8.圖書的歸還功能:</p><p> void Return(LinkList *&L) //歸還</p><p><b> {</b></p><p> LinkList *p=L->next;</p><p> char name1[10];</
71、p><p> printf("輸入歸還書的書名: \n");</p><p> scanf("%s",&name1);</p><p> while(p->next!=NULL&&strcmp(name1,p->data.name)!=0)</p><p> p=
72、p->next;</p><p> if(p->next==NULL&&strcmp(name1,p->data.name)!=0)</p><p> printf("錯誤!此圖書不存在!\n");</p><p> else if(strcmp(name1,p->data.name)==0)<
73、/p><p><b> {</b></p><p> printf("該書歸還成功!\n");</p><p> p->data.count++;</p><p><b> }</b></p><p><b> }</b>
74、</p><p><b> 四.源程序及注釋</b></p><p> #include <stdio.h></p><p> #include <string.h></p><p> #include<stdlib.h> </p><p> #inc
75、lude<malloc.h></p><p> typedef struct </p><p><b> {</b></p><p><b> int num;</b></p><p> char name[20];</p><p> char auth
76、or[20];</p><p> char press[20];</p><p> int count;</p><p> char price[10];</p><p> }ElemType;</p><p> typedef struct LNode//定義單鏈表結(jié)點(diǎn)類型</p><
77、p><b> {</b></p><p> ElemType data;</p><p> struct LNode *next;</p><p> } LinkList;</p><p> void InitList(LinkList *&L) //初始化線性表</p>&l
78、t;p><b> {</b></p><p> L=(LinkList *)malloc(sizeof(LinkList)); //創(chuàng)建頭結(jié)點(diǎn)</p><p> L->next=NULL;</p><p><b> }</b></p><p> int CreateList
79、R(LinkList *&L) //尾插法建表</p><p> { int i,n; </p><p> LinkList *s,*q,*p;</p><p><b> p=L;</b></p><p> while(p->next!=NULL)</p><p
80、> p=p->next;</p><p> printf("請輸入需要錄入的圖書信息的個數(shù):n=");</p><p> scanf("%d",&n);</p><p> for(i=1;i<n+1;i++)</p><p><b> { </b>
81、;</p><p> s=(LinkList *)malloc(sizeof(LinkList));</p><p> printf("書號 書名 作者 出版社名稱 存館數(shù)量 定價\n");</p><p> scanf("%d%s%s%s%d%s",&s->data.num,s->
82、data.name,s->data.author,s->data.press,&s->data.count,s->data.price);</p><p> q=L->next;</p><p> if(q==NULL)</p><p><b> {</b></p><p>
83、 p->next=s; </p><p><b> p=s;</b></p><p> p->next=NULL;</p><p> printf("錄入成功!\n");</p><p><b> continue;</b></p><p&
84、gt;<b> }</b></p><p> while(q!=NULL)</p><p><b> {</b></p><p> if(strcmp(s->data.name,q->data.name)==0)</p><p> { printf("此圖書已存
85、在!");</p><p> printf("請重新輸入:\n");</p><p> scanf("%d%s%s%s%d%s",&p->data.num,p->data.name,p->data.author,p->data.press,&p->data.count,p->data.
86、price);</p><p><b> }</b></p><p> q=q->next;</p><p><b> }</b></p><p> p->next=s; </p><p><b&g
87、t; p=s;</b></p><p> p->next=NULL;</p><p> printf("錄入成功!\n");</p><p><b> } </b></p><p> return 0;</p><p><b> }&l
88、t;/b></p><p> void LocateElem(LinkList *&L) //查詢 </p><p><b> {</b></p><p> LinkList *p=L->next; //p指向第一個數(shù)據(jù)結(jié)點(diǎn)</p><p
89、><b> int c;</b></p><p><b> int x=0;</b></p><p> char name1[10],author1[10],press1[10];</p><p> printf(" 1 按書名查詢:\n");</p><p>
90、 printf(" 2 按作者名查詢:\n");</p><p> printf(" 3 按出版社名稱:\n");</p><p> printf(" 4 返回\n");</p><p> printf(" 請選擇1--4進(jìn)行操作:\n"); </
91、p><p> scanf("%d",&c);</p><p> if(c>4||c<1)</p><p><b> {</b></p><p> printf("您的輸入有誤!\n");</p><p> scanf("%
92、d",&c);</p><p><b> }</b></p><p><b> switch(c)</b></p><p><b> {</b></p><p> case 1:printf("請輸入圖書書名: \n");</
93、p><p> scanf("%s",&name1);</p><p> while(p!=NULL)</p><p><b> {</b></p><p> if(strcmp( name1,p->data.name)!=0) //查找圖書書名</p><p>
94、; p=p->next; </p><p><b> else</b></p><p><b> {</b></p><p> printf("書號 書名 作者 出版社名稱 存館數(shù)量 定價\n");</p><p> printf("%d
95、 %s %s %s %d %s",p->data.num,p->data.name,p->data.author,p->data.press,p->data.count,&p->data.price);</p><p> printf("\n");</p><p&
96、gt; p=p->next;</p><p><b> x++;</b></p><p><b> }</b></p><p><b> } </b></p><p> if (p==NULL&&x==0)</p><p&g
97、t; printf("對不起,不存在此圖書!\n");</p><p><b> break;</b></p><p> case 2:printf("請輸入圖書作者:\n");</p><p> scanf("%s",author1);</p><p>
98、; while(p!=NULL)</p><p><b> {</b></p><p> if(strcmp( author1,p->data.author)!=0)//查找圖書作者 </p><p> p=p->next; </p><p><b> else</b><
99、;/p><p><b> {</b></p><p> printf("書號 書名 作者 出版社名稱 存館數(shù)量 定價\n");</p><p> printf("%d %s %s %s %d %s",p->data.num,p-
100、>data.name,p->data.author,p->data.press,p->data.count,&p->data.price);</p><p> printf("\n");</p><p> p=p->next ;</p><p><b> x++;</b>&
101、lt;/p><p><b> }</b></p><p><b> } </b></p><p> if (p==NULL&&x==0)</p><p> printf("對不起,不存在此圖書!\n");</p><p><b
102、> break;</b></p><p> case 3:printf("請輸入圖書的出版社名稱: \n"); </p><p> scanf("%s",press1);</p><p> while(p!=NULL)</p><p><b> {</b
103、></p><p> if(strcmp( press1,p->data.press)!=0)//查找圖書出版社名稱 </p><p> p=p->next; </p><p><b> else</b></p><p><b> {</b></p>&l
104、t;p> printf("書號 書名 作者 出版社名稱 存館數(shù)量 定價\n");</p><p> printf("%d %s %s %s %d %s",p->data.num,p->data.name,p->data.author,p->data.press,p->
105、;data.count,&p->data.price);</p><p> printf("\n");</p><p> p=p->next;</p><p><b> x++;</b></p><p><b> }</b></p>&l
106、t;p><b> } </b></p><p> if (p==NULL&&x==0)</p><p> printf("對不起!不存在此圖書\n");</p><p><b> break;</b></p><p><b> case
107、 4:</b></p><p><b> break;</b></p><p><b> }</b></p><p><b> }</b></p><p> int Sort(LinkList *&L) //遞增有序排序(直接插入排序法)&l
108、t;/p><p><b> {</b></p><p> LinkList *p=L->next,*q,*r; //p指向第一個數(shù)據(jù)結(jié)點(diǎn)</p><p> if(p!=NULL) //若原單鏈表中有一個或以上的數(shù)據(jù)結(jié)點(diǎn)</p><p><b> {</b>&l
109、t;/p><p> r=p->next; //r保存*p結(jié)點(diǎn)直接后繼結(jié)點(diǎn)的指針</p><p> p->next=NULL; //構(gòu)造只含一個數(shù)據(jù)結(jié)點(diǎn)的有序表</p><p><b> p=r;</b></p><p> while(p!=NULL)</p>
110、;<p><b> {</b></p><p> r=p->next; //r保存*p結(jié)點(diǎn)的直接后繼結(jié)點(diǎn)的指針</p><p><b> q=L;</b></p><p> while(q->next!=NULL&&q->next->data.nu
111、m<p->data.num)</p><p> q=q->next; //在有序表中找插入*p的直接前驅(qū)結(jié)點(diǎn)*q的位置</p><p> p->next=q->next; //將*p插入到*q之后</p><p> q->next=p;</p><p> p=r;
112、//掃描原單鏈表余下的結(jié)點(diǎn)</p><p><b> }</b></p><p><b> }</b></p><p><b> return 0;</b></p><p><b> }</b></p><p> void
113、 Display(LinkList *&L) //輸出排序結(jié)果</p><p><b> {</b></p><p> LinkList *p=L->next;</p><p> while (p!=NULL)</p><p><b> {</b></p>&
114、lt;p> printf("書號 書名 作者 出版社名稱 存館數(shù)量 定價\n");</p><p> printf("%d %s %s %s %d %s",p->data.num,p->data.name,p->data.author,p->data.press,p->data.co
115、unt,p->data.price);</p><p> printf("\n");</p><p> p=p->next;</p><p><b> }</b></p><p><b> }</b></p><p> int Mod
116、ifyList(LinkList *&L) //修改</p><p> { </p><p> LinkList *p=L;</p><p> char name1[10];</p><p> printf("請輸入要修改的圖書的書名:\n");</p
117、><p> scanf("%s",name1);</p><p> while(p!=NULL)</p><p><b> {</b></p><p> if(strcmp(name1,p->data.name)==0) //查找所要修改的書名</p><p><
118、;b> { </b></p><p> printf("請輸入修改后的信息!\n");</p><p> printf("書號 書名 作者 出版社名稱 存館數(shù)量 定價\n");</p><p> scanf("%d%s%s%s%d%s",&p->d
119、ata.num,p->data.name,p->data.author,p->data.press,&p->data.count,p->data.price);</p><p> printf("修改成功!\n"); </p><p><b> return 0;</b></p><p
120、><b> }</b></p><p> p=p->next;</p><p><b> }</b></p><p> printf("不存在此圖書\n");</p><p><b> return 0;</b></p>
121、<p><b> }</b></p><p> int ListDelete(LinkList *&L) //刪除 </p><p> { LinkList *p=L->next,*q=L;</p><p> char name1[10];</p><p>
122、if(p!=NULL)</p><p><b> {</b></p><p> printf("請輸入要刪除的書名:");</p><p> scanf("%s",&name1);</p><p><b> }</b></p>&
123、lt;p> while(p->next!=NULL&&strcmp(p->data.name,name1)!=0)</p><p><b> {</b></p><p> p=p->next;</p><p> q=q->next;</p><p><b>
124、 }</b></p><p> if(p->next!=NULL) //如果p此時不是最后一個節(jié)點(diǎn),說明此時已經(jīng)找到書</p><p><b> {</b></p><p> q->next=p->next;</p><p> printf("刪除成功!\n"
125、;);</p><p><b> return 0;</b></p><p><b> } </b></p><p> if(p->next==NULL&&strcmp(name1,p->data.name)!=0) //如果p此時為最后一個結(jié)點(diǎn)并且沒有找到與之相符的書名</p>
126、;<p><b> {</b></p><p> printf("你輸入的書名不存在,請核實(shí)后重新輸入!\n");</p><p><b> } </b></p><p><b> else</b></p><p><b>
127、 {</b></p><p> q->next=NULL;</p><p> printf("刪除成功!\n");</p><p><b> }</b></p><p><b> return 0;</b></p><p>&
128、lt;b> }</b></p><p> void Borrow(LinkList *&L) //借閱</p><p><b> {</b></p><p> LinkList *p=L->next;</p><p> char name1[10];</p>
129、<p> printf("請輸入要借閱的圖書的書名:\n");</p><p> scanf("%s",&name1);</p><p> while(p->next!=NULL&&strcmp(name1,p->data.name)!=0)</p><p> p=p-&g
130、t;next;</p><p> if(p->next==NULL&&strcmp(name1,p->data.name)!=0)</p><p> printf("此圖書不存在!\n");</p><p> else if(p->data.count<1) </p><p
131、> printf("此書已借完!\n") ;</p><p> else if(strcmp(name1,p->data.name)==0)</p><p><b> {</b></p><p> printf("借書成功!\n");</p><p> p-&
132、gt;data.count--;</p><p><b> }</b></p><p><b> }</b></p><p> void Return(LinkList *&L) //歸還</p><p><b> {</b></p><
133、p> LinkList *p=L->next;</p><p> char name1[10];</p><p> printf("輸入歸還書的書名: \n");</p><p> scanf("%s",&name1);</p><p> while(p->next!
134、=NULL&&strcmp(name1,p->data.name)!=0)</p><p> p=p->next;</p><p> if(p->next==NULL&&strcmp(name1,p->data.name)!=0)</p><p> printf("錯誤!此圖書不存在!\n&qu
135、ot;);</p><p> else if(strcmp(name1,p->data.name)==0)</p><p><b> {</b></p><p> printf("該書歸還成功!\n");</p><p> p->data.count++;</p>&
136、lt;p><b> }</b></p><p><b> }</b></p><p> void main() //主函數(shù)</p><p><b> {</b></p><p><b> int s;</b></p>
137、;<p> LinkList *L;</p><p> L=(LinkList *)malloc(sizeof(LinkList)); </p><p> InitList(*&L);</p><p> w:while(s!=0){</p><p> printf("-----------------
138、-------------------------------------------------- \n");</p><p> printf(" 歡迎光臨圖書管理系統(tǒng)! \n");</p><p> printf("-----------------
139、-------------------------------------------------- \n");</p><p> printf("1.圖書信息錄入添加功能:\n");</p><p> printf("2.圖書信息查詢功能:\n"); </p><p> printf("3.圖書信
140、息排序功能:\n");</p><p> printf("4.圖書的修改功能:\n");</p><p> printf("5.圖書的刪除功能:\n");</p><p> printf("6.圖書借閱功能:\n");</p><p> printf("7
141、.圖書歸還功能:\n");</p><p> printf("0.退出系統(tǒng):\n");</p><p> printf("請選擇你需要的操作:\n");</p><p> scanf("%d",&s);</p><p><b> switch(s)
142、</b></p><p><b> {</b></p><p> case 1: CreateListR(L);break;</p><p> case 2: LocateElem(L);break;</p><p> case 3: Sort(L);Display(L);break;</p&g
143、t;<p> case 4: ModifyList(L);break;</p><p> case 5:ListDelete(L); break;</p><p> case 6:Borrow(L); break;</p><p> case 7:Return(L); break;</p><p> ccase 0:p
144、rintf("謝謝使用\n");return 0;break;goto w;}</p><p><b> }</b></p><p><b> }</b></p><p> 五、運(yùn)行示例及結(jié)果分析</p><p><b> (一)界面輸出:</b>
145、;</p><p> 系統(tǒng)運(yùn)行以后即可進(jìn)入菜單</p><p> (二)圖書信息錄入添加功能:</p><p> 按提示依次錄入信息即可。</p><p> (三)圖書信息查詢功能:</p><p> 可選擇按書名、作者名、出版社名稱查詢。若所要查詢的圖書不存在,會有相應(yīng)的提示。</p><
146、;p> (四)圖書信息排序功能:</p><p> 按照圖書書號的大小遞增排序。</p><p> (五)圖書的修改功能:</p><p> 根據(jù)提示輸入要修改的書名,再錄入修改后的信息即可。</p><p> (六)圖書的刪除功能:</p><p> 根據(jù)提示輸入要刪除的書名。</p>
147、<p> (七)圖書借閱功能:</p><p> 根據(jù)提示輸入要借閱的書名。若圖書不存在或圖書已借完會有相應(yīng)的提示。</p><p> (八)圖書歸還功能:</p><p> 根據(jù)提示輸入要?dú)w還的書名。若圖書不存在會有相應(yīng)的提示。</p><p><b> (九)退出程序:</b></p>
148、;<p> 調(diào)試和運(yùn)行程序過程中產(chǎn)生的問題及采取的措施</p><p><b> 問題:</b></p><p> 錄入圖書信息后,輸出圖書信息時有些項(xiàng)目輸出亂碼。</p><p><b> 采取的措施:</b></p><p> 在輸入語句中,定義為int型的項(xiàng)目在輸入語句
149、中加上取地址符號“&”。</p><p><b> (二)問題:</b></p><p> 執(zhí)行查詢功能時,按作者或是按出版社查詢,若出現(xiàn)多本書均為同一作者所作或是同一出版社出版,只能輸出一本書的信息。</p><p><b> 采取的措施:</b></p><p> 將輸出語句放到
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)圖書管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--圖書管理系統(tǒng)
- 《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計(jì)---圖書管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--圖書管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---圖書管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)圖書管理系統(tǒng)實(shí)驗(yàn)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-圖書管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-圖書管理
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--圖書管理
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告——圖書管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告圖書管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告--學(xué)院圖書管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)——圖書管理信息系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)圖書館管理系統(tǒng)
- 數(shù)據(jù)庫課程設(shè)計(jì)圖書管理系統(tǒng)
- 課程設(shè)計(jì)---課程設(shè)計(jì)圖書管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告---- 圖書管理系統(tǒng)的設(shè)計(jì)與實(shí)現(xiàn)
- 數(shù)據(jù)結(jié)構(gòu)-圖書管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--圖書借閱管理系統(tǒng)
- 圖書管理系統(tǒng)(含源代碼)c語言_數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告
評論
0/150
提交評論