版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p><b> 目 錄</b></p><p> 一、設(shè)計(jì)任務(wù)說(shuō)明2</p><p><b> 二、需求分析2</b></p><p> 2.1系統(tǒng)結(jié)構(gòu)圖(功能模塊圖)2</p><p> 2.2 系統(tǒng)能實(shí)現(xiàn)的操作和功能3</p><p>
2、三、設(shè)計(jì)方案(程序流程圖)4</p><p><b> 四、測(cè)試分析9</b></p><p> 4.1程序的模塊9</p><p> 4.2測(cè)試結(jié)果分析9</p><p><b> 五、總結(jié)13</b></p><p> 5.1總體過(guò)程13</p
3、><p> 5.2問(wèn)題和不足13</p><p> 5.3調(diào)試體會(huì)14</p><p><b> 參考文獻(xiàn)14</b></p><p><b> 一、設(shè)計(jì)任務(wù)說(shuō)明</b></p><p> 1. 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)是綜合運(yùn)用數(shù)據(jù)結(jié)構(gòu)課程中學(xué)到的幾種典型數(shù)據(jù)結(jié)構(gòu),以
4、及程序設(shè)計(jì)語(yǔ)言(C語(yǔ)言),自行實(shí)現(xiàn)一個(gè)較為完整的應(yīng)用系統(tǒng)的設(shè)計(jì)與開(kāi)發(fā)</p><p> 2. 通過(guò)課程設(shè)計(jì),自己通過(guò)系統(tǒng)分析、系統(tǒng)設(shè)計(jì)、編程調(diào)試,寫(xiě)實(shí)驗(yàn)報(bào)告等環(huán)節(jié),進(jìn)一步掌握應(yīng)用系統(tǒng)設(shè)計(jì)的方法和步驟,靈活運(yùn)用并深刻理解典型數(shù)據(jù)結(jié)構(gòu)在軟件開(kāi)發(fā)中的應(yīng)用 。</p><p> 3. 學(xué)會(huì)將知識(shí)應(yīng)用于實(shí)際的方法,提高分析和解決問(wèn)題的能力,增加綜合能力。</p><p&g
5、t; 4. 航空空訂票系統(tǒng):</p><p> (1)熟練掌握鏈表存儲(chǔ)結(jié)構(gòu)及其建立過(guò)程和常用操作;</p><p> (2)熟練掌握隊(duì)列的建立過(guò)程和常用操作;</p><p> (3)學(xué)會(huì)自己調(diào)試程序的方法并掌握一定的技巧。</p><p> 航空客運(yùn)訂票的業(yè)務(wù)活動(dòng)包括:查詢(xún)航線、客票預(yù)訂和辦理退票等。設(shè)計(jì)一個(gè)航空客運(yùn)訂票系統(tǒng),
6、以使上述業(yè)務(wù)可以借助計(jì)算機(jī)來(lái)完成。</p><p><b> 二、需求分析</b></p><p> 2.1系統(tǒng)結(jié)構(gòu)圖(功能模塊圖)</p><p> 每條航線所涉及的信息有:終點(diǎn)站名、航班號(hào)、飛機(jī)號(hào)、飛行日(星期幾)、乘員定額、余票量、已訂票的客戶名單(包括姓名、訂票量、艙位等級(jí)1,2或3)以及等候替補(bǔ)的客戶名單(包括姓名、所需票量);
7、 全部數(shù)據(jù)可以只放在內(nèi)存中; </p><p> 2.2 系統(tǒng)能實(shí)現(xiàn)的操作和功能 </p><p> 1. 查詢(xún)航線: </p><p> 根據(jù)旅客提出的終點(diǎn)站名輸出下列信息:航班號(hào)、飛機(jī)號(hào)、星期幾飛行,最近一天航班的日期和余票額; </p><p> 2.辦理訂票業(yè)務(wù): </p><p>
8、 根據(jù)客戶提出的要求(航班號(hào)、訂票數(shù)額)查詢(xún)?cè)摵桨嗥鳖~情況,若尚有余票,則為客戶辦理訂票手續(xù), </p><p> 輸出座位號(hào);若已滿員或余票額少于定票額,則需重新詢(xún)問(wèn)客戶要求。若需要,可登記排隊(duì)候補(bǔ); </p><p> 3. 辦理退票業(yè)務(wù): </p><p> 根據(jù)客戶提供的情況(日期、航班),為客戶辦理退票手續(xù),然后查詢(xún)?cè)摵桨嗍欠裼腥伺抨?duì)候
9、補(bǔ),首先詢(xún)問(wèn)排在第一的客戶,若所退票額能滿足他的要求,則為他辦理訂票手續(xù),否則依次詢(xún)問(wèn)其他排隊(duì)候補(bǔ)的客戶。 </p><p> 三、設(shè)計(jì)方案(程序流程圖)</p><p> 3.1顯示已初始化的全部航線信息</p><p> 3.2瀏覽已訂票客戶信息</p><p><b> 3.3查詢(xún)航線</b></
10、p><p> 根據(jù)客戶提出的終點(diǎn)站名,調(diào)用find()函數(shù)尋找航線信息,調(diào)用list()函數(shù)輸出航線信息。</p><p> 經(jīng)過(guò)分析可以畫(huà)出查詢(xún)航線算法的模塊分析圖如下圖所示:</p><p><b> 3.4辦理訂票業(yè)務(wù)</b></p><p> 根據(jù)客戶提供的航班號(hào)進(jìn)行查詢(xún)航線信息,若客戶訂票額超過(guò)乘員定票總額
11、,退出,若客戶訂票額末超過(guò)余票量,訂票成功并登記信息,在訂票乘員名單域中添加客戶信息;如果暫時(shí)沒(méi)有票,詢(xún)問(wèn)客戶是否要排隊(duì)等侯,如果是,則在等候隊(duì)列增加該客戶的訂票信息。</p><p> 經(jīng)過(guò)分析可以得出此業(yè)務(wù)算法的流程圖分析結(jié)果如下圖所示:</p><p><b> 3.5辦理退票業(yè)務(wù)</b></p><p> 調(diào)用查詢(xún)函數(shù),根據(jù)客戶提
12、供的航線進(jìn)行搜索根據(jù)客戶提供的姓名到訂票客戶名單域進(jìn)行查詢(xún)。退票成功后,重新將航線名單域指向訂票單鏈表的頭指針。根據(jù)隊(duì)列中從出的客戶信息判斷是否滿足要求,如果滿足,則將該客戶的信息插入到乘客信息鏈表中。</p><p> 經(jīng)過(guò)分析,可以得出關(guān)于辦理退票業(yè)務(wù)的算法的流程分析圖分析結(jié)果如下圖所示:</p><p><b> 四、測(cè)試分析</b></p>
13、<p><b> 4.1程序的模塊</b></p><p> 錄入功能:原始數(shù)據(jù)的輸入(通過(guò)文件輸入航線的基本信息)。</p><p> 查詢(xún)功能:根據(jù)客戶需要,查詢(xún)相關(guān)航線。</p><p> 訂票功能:滿足客戶的訂票任務(wù)。</p><p> 退票功能:根據(jù)客戶的不同情況,支持客戶的退票請(qǐng)求。<
14、;/p><p> 退出功能:退出系統(tǒng)。</p><p><b> 4.2測(cè)試結(jié)果分析</b></p><p><b> ?。?)瀏覽航線信息</b></p><p> 圖4.2.1 輸入1,通過(guò)文件進(jìn)行航線原始數(shù)據(jù)的輸入</p><p> ?。?)瀏覽已訂票客戶信息<
15、;/p><p> 下面是有客戶訂票以及無(wú)客戶訂票的兩種測(cè)試分析結(jié)果:</p><p> 圖4.2.2輸入2,通過(guò)輸入航班號(hào)3瀏覽已訂票客戶信息</p><p> 圖4.2.3輸入2,通過(guò)輸入航班號(hào)1瀏覽已訂票客戶信息</p><p><b> ?。?)查詢(xún)航線</b></p><p> 下列截
16、圖是以”shanghai”為例的航線查詢(xún)結(jié)果:</p><p> 圖4.2.4輸入3,通過(guò)輸入終點(diǎn)站名查詢(xún)航線信息</p><p><b> 辦理訂票業(yè)務(wù)</b></p><p> 圖4.2.5 輸入4,通過(guò)輸入終點(diǎn)站名,進(jìn)行訂票</p><p><b> 辦理退票業(yè)務(wù)</b></p
17、><p> 圖4.2.6 輸入5,通過(guò)輸入退票客戶信息進(jìn)行退票</p><p><b> 退出訂票系統(tǒng)</b></p><p> 圖4.2.7 輸入6,退出訂票系統(tǒng)</p><p><b> 五、總結(jié)</b></p><p><b> 5.1總體過(guò)程<
18、;/b></p><p> 編譯和調(diào)試工具:選擇V C++6.0,該工具穩(wěn)定,其中有一個(gè)強(qiáng)大的調(diào)試工具,但我不是很熟悉,還需要進(jìn)一步的學(xué)習(xí)和練習(xí),不斷地完善自己,提高自己的編譯能力。</p><p><b> 5.2問(wèn)題和不足</b></p><p> 1.在將近一周的時(shí)間里,不斷地對(duì)程序及各模塊進(jìn)行修改、編譯、調(diào)試、運(yùn)行,其間遇到
19、很多問(wèn)題:</p><p> (1)程序在起初設(shè)計(jì)的時(shí)候,經(jīng)常出現(xiàn)溢出錯(cuò)誤,而且不只一處。為了修正這些溢出錯(cuò)誤,耗費(fèi)了大量的時(shí)間,修正解釋之后再看源程序,才發(fā)現(xiàn)原來(lái)只是因?yàn)殚_(kāi)始的函數(shù)定義的數(shù)據(jù)類(lèi)型出現(xiàn)了問(wèn)題,對(duì)函數(shù)的定義不清楚,字符的不正確定義造成了后期大量的糾錯(cuò)工作. </p><p> ?。?)由于忘記了一些c語(yǔ)言的規(guī)范使得在調(diào)試過(guò)程中一些錯(cuò)誤沒(méi)有發(fā)現(xiàn)。例如,調(diào)用函數(shù)時(shí),數(shù)組只需要傳
20、遞數(shù)組名即可;字符‘0’和整型的0是不同的,不可以直接對(duì)其畫(huà)等號(hào)。</p><p> ?。?)測(cè)試用例具有一定的廣泛性。運(yùn)行程序時(shí)輸入了多種不同字符信息,經(jīng)過(guò)多次修改結(jié)果達(dá)到了預(yù)期效果,說(shuō)明程序具有一定的可靠性和穩(wěn)定性。</p><p> 2.經(jīng)過(guò)不斷地學(xué)習(xí),我也終于結(jié)束了這次的課程設(shè)計(jì),雖然最后也受益匪淺,但是其中仍顯現(xiàn)出許多的不足:</p><p> (1)
21、錄入系統(tǒng),每次輸入的數(shù)據(jù)會(huì)覆蓋上次輸入的數(shù)據(jù)。</p><p> ?。?)查詢(xún)系統(tǒng),只能查找最近輸入的數(shù)據(jù),并且相同終點(diǎn)站只能顯現(xiàn)一個(gè)信息。</p><p> ?。?)在數(shù)據(jù)初始化的時(shí)候未對(duì)數(shù)據(jù)按照一定的順序存放,如果航線信息較多時(shí)將影響系統(tǒng)功能。</p><p><b> 5.3調(diào)試體會(huì)</b></p><p>
22、經(jīng)過(guò)這次實(shí)習(xí),我對(duì)調(diào)試掌握的更加熟練了,盡自己的努力,改變了過(guò)去只調(diào)試不知道如何對(duì)照程序語(yǔ)言修改程序的壞習(xí)慣,對(duì)調(diào)試也有了新的認(rèn)識(shí),意識(shí)到了程序語(yǔ)言的規(guī)范性以及我們?cè)诰幊虝r(shí)要有嚴(yán)謹(jǐn)?shù)膽B(tài)度,同時(shí)在寫(xiě)程序時(shí)如果加一定量的注釋?zhuān)仍黾恿顺绦虻目勺x性,也可以使自己在讀程序時(shí)更容易。 </p><p><b> 參考文獻(xiàn)</b></p><p> [1]譚浩強(qiáng) 編著,《C
23、程序設(shè)計(jì)》 ,北京清華大學(xué)出版社,1998年9月。</p><p> [2]傅清祥等,《算法與數(shù)據(jù)結(jié)構(gòu)》,北京電子工業(yè)出版社,1998年。</p><p> [3]譚浩強(qiáng),《C++程序設(shè)計(jì)題解與上機(jī)指導(dǎo)》 ,北京清華大學(xué)出版社,2004年3月。</p><p> [4]田淑清等,《C語(yǔ)言程序設(shè)計(jì)輔導(dǎo)與習(xí)題集》,中國(guó)鐵道出版社,2000年1月。</p>
24、;<p> [5]譚浩強(qiáng)等編著,《算法與數(shù)據(jù)結(jié)構(gòu)》 ,中國(guó)鐵道出版社,2003年9月。</p><p> [6]柴欣,C/C++程序設(shè)計(jì),河北大學(xué)出版社,2002年。</p><p><b> 源代碼:</b></p><p> /*航空票務(wù)管理系統(tǒng)源代碼*/</p><p> #include
25、<stdio.h></p><p> #include <stdlib.h></p><p> #include <string.h></p><p> #define MAXSIZE 3 /*定義航線量的最大值*/</p><p> typedef struct wat_ros</p>
26、<p> { char name[10];/*姓名*/</p><p> int req_amt;/*訂票量*/</p><p> struct wat_ros *next;</p><p> }qnode,*qptr;</p><p> typedef struct pqueue</p><p&
27、gt; { qptr front;/*等候替補(bǔ)客戶名單域的頭指針*/</p><p> qptr rear;/*等候替補(bǔ)客戶名單域的屬指針*/</p><p> }linkqueue;</p><p> typedef struct ord_ros</p><p> { char name[10];/*客戶姓名*/</p&
28、gt;<p> int ord_amt;/*訂票量*/</p><p> int grade;/*艙位等級(jí)*/</p><p> struct ord_ros *next;</p><p> }linklist;</p><p> struct airline</p><p> { cha
29、r ter_name[10];/*終點(diǎn)站名 */</p><p> char air_num[10];/*航班號(hào)*/</p><p> char plane_num[10];/*飛機(jī)號(hào)*/</p><p> char day[7];/*飛行周日(星期幾)*/</p><p> int tkt_amt;/*乘員定額*/</p>
30、;<p> int tkt_sur;/*余票量*/</p><p> linklist *order;/*乘員名單域,指向乘員名單鏈表的頭指針*/</p><p> linkqueue wait;/*等候替補(bǔ)的客戶名單域,分別指向排隊(duì)等候名單隊(duì)頭隊(duì)尾的指針*/</p><p> }lineinfo;</p><p>
31、struct airline *start;</p><p> void display(struct airline *info)</p><p> /*打印每條航線的基本信息*/</p><p> {printf("%8s\t%3s\t%s\t%4s\t\t%3d\t%10d\n",info->ter_name,info->
32、air_num,info->plane_num,info->day,info->tkt_amt,info->tkt_sur);</p><p><b> }</b></p><p> void list()/*打印全部航線信息*/</p><p> { struct airline *info;</p>
33、;<p><b> int i=0;</b></p><p> info=start;</p><p> printf("終點(diǎn)站名\t航班號(hào)\t飛機(jī)號(hào)\t飛行周日\(chéng)t乘員定額\t余票量\n");</p><p> while(i<MAXSIZE){</p><p> di
34、splay(info);</p><p><b> info++;</b></p><p><b> i++;</b></p><p><b> }</b></p><p> printf("\n\n");</p><p>&
35、lt;b> }</b></p><p> void search()</p><p> /*根據(jù)客戶提出的終點(diǎn)站名輸出航線信息*/</p><p> { struct airline *info,*find();</p><p> char name[10];</p><p><b&
36、gt; int i=0;</b></p><p> info=start;</p><p> printf("請(qǐng)輸入終點(diǎn)站名:");</p><p> scanf("%s",name);</p><p> while(i<MAXSIZE) {</p><p
37、> if(!strcmp(name,info->ter_name)) break;</p><p><b> info++;</b></p><p><b> i++;</b></p><p><b> }</b></p><p> if(i>=MA
38、XSIZE)</p><p> printf("對(duì)不起,該航線未找到!\n");</p><p><b> else{</b></p><p> printf("終點(diǎn)站名\t航班號(hào)\t飛機(jī)號(hào)\t飛行周日\(chéng)t乘員定額\t余票量\n");</p><p> display(in
39、fo);</p><p><b> }</b></p><p><b> }</b></p><p> struct airline *find()</p><p> /*根據(jù)系統(tǒng)提出的航班號(hào)查詢(xún)并以指針形式返回*/</p><p> { struct airli
40、ne *info;</p><p> char number[10];</p><p><b> int i=0;</b></p><p> info=start;</p><p> printf("請(qǐng)輸入航班號(hào):");</p><p> scanf("%s
41、",number);</p><p> while(i<MAXSIZE) {</p><p> if(!strcmp(number,info->air_num)) return info;</p><p><b> info++;</b></p><p><b> i++;<
42、/b></p><p><b> }</b></p><p> printf("對(duì)不起,該航線末找到!\n");</p><p> return NULL;</p><p><b> }</b></p><p> void prtlink(
43、)</p><p> /*打印訂票乘員名單域的客戶名單信息*/</p><p> { linklist *p;</p><p> struct airline *info;</p><p> info=find();</p><p> p=info->order;</p><p&g
44、t; if(p!=NULL){</p><p> printf("客戶姓名 訂票數(shù)額 艙位等級(jí)\n");</p><p><b> while(p){</b></p><p> printf("%s\t\t%d\t%d\n",p->name,p->ord_amt,p->g
45、rade);</p><p> p=p->next;</p><p><b> }</b></p><p><b> }</b></p><p><b> else</b></p><p> printf("該航線沒(méi)有客戶信息!
46、!\n");</p><p><b> }</b></p><p> linklist *insertlink(linklist *head,int amount,char name[],int grade)</p><p> /*增加訂票乘員名單域的客戶信息*/</p><p> { linklis
47、t *p1,*new;</p><p><b> p1=head;</b></p><p> new=(linklist *)malloc(sizeof(linklist));</p><p> if(!new) {printf("\nOut of memory!!\n");return NULL;}</p>
48、;<p> strcpy(new->name,name);</p><p> new->ord_amt=amount;</p><p> new->grade=grade;</p><p> new->next=NULL;</p><p> if(head==NULL)/*若原無(wú)訂票客戶信息*/
49、</p><p> {head=new;new->next=NULL;}</p><p><b> else</b></p><p><b> head=new;</b></p><p> new->next=p1;</p><p> return he
50、ad;</p><p><b> }</b></p><p> linkqueue appendqueue(linkqueue q,char name[],int amount)</p><p> /*增加排隊(duì)等候的客戶名單域*/</p><p> { qptr new;</p><p>
51、 new=(qptr)malloc(sizeof(qnode));</p><p> strcpy(new->name,name);</p><p> new->req_amt=amount;</p><p> new->next=NULL;</p><p> if(q.front==NULL)/*若原排隊(duì)等候客戶
52、名單域?yàn)榭?/</p><p> q.front=new;</p><p><b> else</b></p><p> q.rear->next=new;</p><p> q.rear=new;</p><p><b> return q;</b><
53、/p><p><b> }</b></p><p> void order()</p><p> /*辦理訂票業(yè)務(wù)*/</p><p> { struct airline *info;</p><p> int amount,grade;</p><p> cha
54、r name[10];</p><p> info=start;</p><p> if(!(info=find())) return;/*根據(jù)客戶提供的航班號(hào)進(jìn)行查詢(xún),如為空,退出該模塊*/</p><p> printf("請(qǐng)輸入你訂票所需要的數(shù)量:");</p><p> scanf("%d&quo
55、t;,&amount);</p><p> if(amount>info->tkt_amt)/*若客戶訂票額超過(guò)乘員定票總額,退出*/</p><p> { printf("\n對(duì)不起,您輸入的票的數(shù)量已經(jīng)超過(guò)乘員定額!");</p><p><b> return;</b></p>
56、<p><b> }</b></p><p> if(amount<=info->tkt_sur)/*若客戶訂票額末超過(guò)余票量,訂票成功并等記信息*/</p><p><b> {</b></p><p><b> int i;</b></p><p
57、> printf("請(qǐng)輸入您的姓名(訂票客戶):");</p><p> scanf("%s",name);</p><p> printf("請(qǐng)輸入%s票的艙位等級(jí):",name);</p><p> scanf("%d",&grade);</p>
58、<p> info->order=insertlink(info->order,amount,name,grade);/*在訂票乘員名單域中添加客戶信息*/</p><p> for(i=0;i<amount;i++)/*依次輸出該訂票客戶的座位號(hào)*/</p><p> printf("%s的座位號(hào)是:%d\n",name,info-&
59、gt;tkt_amt-info->tkt_sur+i+1);</p><p> info->tkt_sur-=amount;/*該航線的余票量應(yīng)減掉該客戶的訂票量*/</p><p> printf("\n祝您乘坐愉快!\n");</p><p><b> }</b></p><p>
60、; else /*若滿員或余票額少于訂票額,詢(xún)問(wèn)客戶是否需要進(jìn)行排隊(duì)等候*/</p><p> { char r;</p><p> printf("\n已經(jīng)沒(méi)有更多的票,您需要排隊(duì)等候嗎?(Y/N)");</p><p> r=getch();</p><p> printf("%c&q
61、uot;,r);</p><p> if(r=='Y'||r=='y')</p><p> { printf("\n請(qǐng)輸入您的姓名(排隊(duì)訂票客戶):");</p><p> scanf("%s",name);</p><p> info->wait=app
62、endqueue(info->wait,name,amount);/*在排隊(duì)等候乘員名單域中添加客戶信息*/</p><p> printf("\n注冊(cè)成功!\n");</p><p><b> }</b></p><p> else printf("\n歡迎您下次再次訂購(gòu)!\n");<
63、/p><p><b> }</b></p><p><b> }</b></p><p> void return_tkt()</p><p><b> /*退票模塊*/</b></p><p> { struct airline *info;&
64、lt;/p><p> qnode *t,*back,*f,*r;</p><p> int grade;</p><p> linklist *p1,*p2,*head;</p><p> char cusname[10];</p><p> if(!(info=find())) return;/*調(diào)用查詢(xún)函數(shù),
65、根據(jù)客戶提供的航線進(jìn)行搜索*/</p><p> head=info->order;</p><p><b> p1=head;</b></p><p> printf("請(qǐng)輸入你的姓名(退票客戶):");</p><p> scanf("%s",cusname);&
66、lt;/p><p> while(p1!=NULL) {/*根據(jù)客戶提供的姓名到訂票客戶名單域進(jìn)行查詢(xún)*/</p><p> if(!strcmp(cusname,p1->name)) break;</p><p> p2=p1;p1=p1->next;</p><p><b> }</b></p&
67、gt;<p> if(p1==NULL){ printf("對(duì)不起,你沒(méi)有訂過(guò)票!\n");return;}/*若未找到,退出本模塊*/</p><p> else{/*若信息查詢(xún)成功,刪除訂票客戶名單域中的信息*/</p><p> if(p1==head) head=p1->next;</p><p> else
68、p2->next=p1->next;</p><p> info->tkt_sur+=p1->ord_amt;</p><p> grade=p1->grade;</p><p> printf("%s成功退票!\n",p1->name);</p><p><b> f
69、ree(p1);</b></p><p><b> }</b></p><p> info->order=head;/*重新將航線名單域指向訂票單鏈表的頭指針 */</p><p> f=(info->wait).front;/*f指向排隊(duì)等候名單隊(duì)列的頭結(jié)點(diǎn)*/</p><p> r=(
70、info->wait).rear;/*r指向排隊(duì)等候名單隊(duì)列的尾結(jié)點(diǎn)*/</p><p> t=f;/*t為當(dāng)前滿點(diǎn)條件的排隊(duì)候補(bǔ)名單域*/</p><p><b> while(t)</b></p><p><b> {</b></p><p> if(info->tkt_su
71、r>=info->wait.front->req_amt){/*若滿足條件者為頭結(jié)點(diǎn)*/</p><p><b> int i;</b></p><p> info->wait.front=t->next;</p><p> printf("%s訂票成功!\n",t->name);&
72、lt;/p><p> for(i=0;i<t->req_amt;i++)/*輸出座位號(hào)*/</p><p> printf("%s的座位號(hào)是:%d\n",t->name,(info->tkt_sur)-i);</p><p> info->tkt_sur-=t->req_amt;</p><
73、;p> info->order=insertlink(info->order,t->req_amt,t->name,grade);/*插入到訂票客戶名單鏈表中*/</p><p><b> free(t);</b></p><p><b> break;</b></p><p><
74、b> }</b></p><p> back=t;t=t->next;</p><p> if((info->tkt_sur)>=(t->req_amt)&&t!=NULL)/*若滿足條件者不為頭結(jié)點(diǎn)*/</p><p><b> { int i;</b></p>
75、<p> back->next=t->next;</p><p> printf("%s訂票成功!\n",t->name);</p><p> for(i=0;i<t->req_amt;i++)/*輸出座位號(hào)*/</p><p> printf("<%s>'s sea
76、t number is:%d\n",t->name,(info->tkt_sur)-i);</p><p> info->tkt_sur-=t->req_amt;</p><p> info->order=insertlink(info->order,t->req_amt,t->name,grade);/*插入到訂票客戶名單鏈表
77、中*/</p><p> free(t);break;</p><p><b> }</b></p><p> if(f==r) break;</p><p><b> }</b></p><p><b> }</b></p>&
78、lt;p> int menu_select()</p><p><b> /*菜單界面*/</b></p><p><b> { int c;</b></p><p> char s[20];</p><p> printf("\n\t\t航空客運(yùn)訂票系統(tǒng)\n"
79、);</p><p> printf("******************************************\n");</p><p> printf("1.瀏覽航線信息:\n");</p><p> printf("2.瀏覽已訂票客戶信息:\n");</p><p
80、> printf("3.查詢(xún)航線\n");</p><p> printf("4.辦理訂票業(yè)務(wù):\n");</p><p> printf("5.辦理退票業(yè)務(wù):\n");</p><p> printf("6.退出系統(tǒng)\n");</p><p>
81、printf("*******************************************\n");</p><p><b> do{</b></p><p> printf("請(qǐng)選擇:");</p><p> scanf("%s",s);</p>&l
82、t;p> c=atoi(s);</p><p> }while(c<0||c>7);</p><p><b> return c;</b></p><p><b> }</b></p><p><b> main()</b></p>&
83、lt;p> { struct airline air[MAXSIZE]={{"beijing","1","B8571","SUN",3,3},</p><p> {"shanghai","2","S1002","MON",2,2},</p
84、><p> {"london","3","L1003","FRI",1,1}};/*初始化航線信息*/</p><p> /* clrscr();*/</p><p> start=air;</p><p><b> for(;;){</b&
85、gt;</p><p> switch(menu_select()){</p><p> case 1:list();break;</p><p> case 2:prtlink();break;</p><p> case 3:search();break;</p><p> case 4:order();
86、break;</p><p> case 5:return_tkt();break;</p><p> case 6:printf("\n歡迎使用本系統(tǒng),再見(jiàn)!\n");exit(0);</p><p><b> }</b></p><p> printf("\nPress any
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 航空客運(yùn)訂票系統(tǒng)課程設(shè)計(jì)
- 航空客運(yùn)訂票系統(tǒng)課程設(shè)計(jì)報(bào)告
- 航空客運(yùn)訂票系統(tǒng)課程設(shè)計(jì)(數(shù)據(jù)結(jié)構(gòu))
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--航空客運(yùn)訂票系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告---航空客運(yùn)訂票系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)航空航班課程設(shè)計(jì)--航空客運(yùn)訂票系統(tǒng)
- 航空客運(yùn)訂票系統(tǒng)數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)源代碼
- 航空訂票管理系統(tǒng)課程設(shè)計(jì)
- 課程設(shè)計(jì)報(bào)告-航空訂票系統(tǒng)
- java課程設(shè)計(jì)-航空訂票管理系統(tǒng)設(shè)計(jì)
- 數(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)
- 航空訂票系統(tǒng)數(shù)據(jù)庫(kù)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-航空訂票系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---航空訂票系統(tǒng)
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)-- 航空訂票管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)航空訂票系統(tǒng)課程設(shè)計(jì)報(bào)告
- c++課程設(shè)計(jì)報(bào)告_航空訂票系統(tǒng)的菜單設(shè)計(jì)
- 飛機(jī)訂票系統(tǒng)課程設(shè)計(jì)
評(píng)論
0/150
提交評(píng)論