版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、<p><b> 目 錄</b></p><p><b> 一、概述1</b></p><p><b> 二、系統(tǒng)分析1</b></p><p> 1.航班信息的查詢與檢索1</p><p> 2.航班信息查詢與檢索數(shù)據(jù)結(jié)構(gòu)理論1</p&
2、gt;<p><b> 三、概要設(shè)計(jì)2</b></p><p><b> 1.系統(tǒng)的功能2</b></p><p> 2.系統(tǒng)模塊分析及其流程圖3</p><p><b> 四、詳細(xì)設(shè)計(jì)6</b></p><p><b> 1.各函數(shù)說
3、明6</b></p><p> 2.定義相關(guān)數(shù)據(jù)類型8</p><p> 3. 航班信息的查詢9</p><p> 五、 運(yùn)行由于測試12</p><p> 六、總結(jié)與心得16</p><p><b> 參考文獻(xiàn)16</b></p><p>
4、;<b> 附錄16</b></p><p><b> 一、概述</b></p><p> 隨著信息產(chǎn)業(yè)的飛速發(fā)展,信息化管理及查詢已經(jīng)進(jìn)入并應(yīng)用到各行各業(yè),影響著人們的價(jià)值觀念和生活方式。因此,要提高企業(yè)信息化建設(shè),利用先進(jìn)的辦公自動(dòng)化系統(tǒng)來實(shí)現(xiàn)企業(yè)內(nèi)部信息管理、共享及交流,從而提高企業(yè)綜合實(shí)力。</p><p>
5、; 本次設(shè)計(jì)是針對航班的查詢系統(tǒng),該設(shè)計(jì)要求對飛機(jī)航班信息進(jìn)行排序和查詢。可按航班的航班號、起點(diǎn)站、終點(diǎn)站等信息進(jìn)行航班信息的查詢。</p><p><b> 二、系統(tǒng)分析</b></p><p> 1.航班信息的查詢與檢索</p><p> 進(jìn)入系統(tǒng)后,首先提示輸入航班的信息,包括:航班號、起點(diǎn)站、終點(diǎn)站、班期、起飛時(shí)間、到達(dá)時(shí)間、飛
6、機(jī)型號及票價(jià)等,票價(jià)為整型,其他為字符型。</p><p> 當(dāng)輸入完一個(gè)信息后會提示是否繼續(xù)輸入,重復(fù)以上步驟輸入全部的信息。</p><p> 進(jìn)入主菜單后會給出用戶操作的界面,根據(jù)提示進(jìn)行航班信息的查詢。</p><p> 2.航班信息查詢與檢索數(shù)據(jù)結(jié)構(gòu)理論</p><p> 針對在本該類系統(tǒng)中的數(shù)據(jù)的處理情況,本系統(tǒng)采用二分查
7、找法、基數(shù)排序法、最高位優(yōu)先法。</p><p> 二分查找法也稱為折半查找法,它充分利用了元素間的次序關(guān)系,采用分治策略,可在最壞的情況下用O(log n)完成搜索任務(wù)。它的基本思想是,將n個(gè)元素分成個(gè)數(shù)大致相同的兩半,取a[n/2]與欲查找的x作比較,如果x=a[n/2]則找到x,算法終止。如 果x<a[n/2],則我們只要在數(shù)組a的左半部繼續(xù)搜索x(這里假設(shè)數(shù)組元素呈升序排列)。如果x>a[n
8、/2],則我們只要在數(shù)組a的右 半部繼續(xù)搜索x。</p><p> 對航班號的排序是采用的基數(shù)排序法。基數(shù)排序法又稱“桶子法”(bucket sort)或bin sort,顧名思義,它是透過鍵值的部份資訊,將要排序的元素分配至某些“桶”中,藉以達(dá)到排序的作用,基數(shù)排序法是屬于穩(wěn)定性的排序,其時(shí)間復(fù)雜度為O (nlog(r)m),其中r為所采取的基數(shù),而m為堆數(shù),在某些時(shí)候,基數(shù)排序法的效率高于其它的比較性排序法
9、。</p><p> 最高位優(yōu)先(Most Significant Digit first)法,簡稱MSD法:先按k1排序分組,同一組中記錄,關(guān)鍵碼k1相等,再對各組按k2排序分成子組,之后,對后面的關(guān)鍵碼繼續(xù)這樣的排序分組,直到按最次位關(guān)鍵碼kd對各子組排序后。再將各組連接起來,便得到一個(gè)有序序列。最低位優(yōu)先(Least Significant Digit first)法,簡稱LSD法:先從kd開始排序,再對
10、kd-1進(jìn)行排序,依次重復(fù),直到對k1排序后便得到一個(gè)有序序列。</p><p><b> 三、概要設(shè)計(jì)</b></p><p><b> 1.系統(tǒng)的功能</b></p><p> 本任務(wù)要求對飛機(jī)航班信息進(jìn)行排序和查找。可按航班的航班號、起點(diǎn)站、到達(dá)站、起飛時(shí)間以及到達(dá)時(shí)間等信息進(jìn)行查詢。本設(shè)計(jì)主要是對排序以及查找
11、等概念進(jìn)行綜合練習(xí)。以鏈?zhǔn)交鶖?shù)排序?yàn)橹骶€,用到二分查找和順序查找等知識,還有建立靜態(tài)鏈表等相關(guān)概念。</p><p> 2.系統(tǒng)模塊分析及其流程圖</p><p><b> ?。?)航班排序</b></p><p> 對輸入系統(tǒng)內(nèi)的航班首先要進(jìn)行排序,我們采用的基數(shù)排序,從低位到高位依次對關(guān)鍵字進(jìn)行分配和收集,分兩段實(shí)現(xiàn)其算法流程圖。<
12、;/p><p><b> ?。?)時(shí)間查找</b></p><p> 根據(jù)航班的起飛時(shí)間(到達(dá)時(shí)間)查找航班的信息。</p><p> ?。?)二分法查找功能</p><p><b> ?。?)顯示功能</b></p><p> 顯示功能是將所求單詞的所有行列信息依次顯示在屏
13、幕上。</p><p><b> 四、詳細(xì)設(shè)計(jì)</b></p><p><b> 1.各函數(shù)說明</b></p><p><b> 1.一趟分配函數(shù)</b></p><p> void distribute_c(slnode *sl,int i,arrtype_c f,
14、arrtype_c e)</p><p> {//一趟字母分配字符函數(shù)</p><p><b> int j,p;</b></p><p> for(j=0;j<radix_c;j++)</p><p><b> {</b></p><p> f[j]=e[j
15、]=0;</p><p><b> }</b></p><p> for(p=sl[0].next;p;p=sl[p].next)</p><p><b> {</b></p><p> j=sl[p].keys[i]%65;</p><p><b> i
16、f(!f[j])</b></p><p><b> f[j]=p;</b></p><p><b> else</b></p><p> sl[e[j]].next=p;</p><p><b> e[j]=p;</b></p><p&g
17、t;<b> }</b></p><p><b> }</b></p><p><b> 2.一趟收集函數(shù)</b></p><p> void collect_c(slnode *sl,int i,arrtype_c f,arrtype_c e)</p><p><
18、;b> {</b></p><p><b> int j,t;</b></p><p> for(j=0;!f[j];j++);</p><p> sl[0].next=f[j];</p><p><b> t=e[j];</b></p><p>
19、 while(j<radix_c-1)</p><p><b> {</b></p><p> for(j=j+1;j<radix_c-1&&!f[j];j++);</p><p><b> if(f[j])</b></p><p><b> {<
20、;/b></p><p> sl[t].next=f[j];</p><p><b> t=e[j]; </b></p><p><b> }</b></p><p><b> }</b></p><p> sl[t].next=0;&l
21、t;/p><p><b> }</b></p><p><b> 3.鏈?zhǔn)交鶖?shù)排序</b></p><p> void radixsort(sllist &l)//鏈?zhǔn)交鶖?shù)排序函數(shù)</p><p><b> {</b></p><p><
22、;b> int i;</b></p><p> arrtype_n fn,en;</p><p> arrtype_c fc,ec;</p><p> for(i=0;i<l.length;i++)</p><p> l.sl[i].next=i+1;</p><p> l.sl[l
23、.length].next=0;</p><p> for(i=l.keynum-1;i>=2;i--)</p><p><b> {</b></p><p> distribute(l.sl,i,fn,en);</p><p> collect(l.sl,i,fn,en);</p><
24、p><b> }</b></p><p> for(i=1;i>=0;i--)</p><p><b> {</b></p><p> distribute_c(l.sl,i,fc,ec);</p><p> collect_c(l.sl,i,fc,ec);</p>
25、<p><b> }</b></p><p><b> }</b></p><p><b> 4.二分法查找函數(shù)</b></p><p> int binsearch(sllist l,keytype key[])</p><p><b> {
26、</b></p><p> int low,high,mid;</p><p><b> low=1;</b></p><p> high=l.length;</p><p> while(low<=high)</p><p><b> {</b>
27、</p><p> mid=(low+high)/2;</p><p> if(strcmp(key,l.sl[mid].keys)==0)</p><p> return mid;</p><p> else if(strcmp(key,l.sl[mid].keys)<0)</p><p> high
28、=mid-1;</p><p><b> else</b></p><p> low=mid+1;</p><p><b> }</b></p><p><b> return 0;</b></p><p><b> }</b&
29、gt;</p><p> 2.定義相關(guān)數(shù)據(jù)類型</p><p> 根據(jù)設(shè)計(jì)要求我們知道所用的記錄中只有航班信息,因此要定義相關(guān)的數(shù)據(jù)類型,其源程序如下:</p><p> typedef struct </p><p><b> {</b></p><p> char start[6];
30、//起點(diǎn)</p><p> char end[6]; //終點(diǎn)</p><p> char sche[10];//班期</p><p> char time1[5];//起飛時(shí)間</p><p> char time2[5];//到達(dá)時(shí)間</p><p> char model[4];//機(jī)型</p&
31、gt;<p> int price; //票價(jià)</p><p> }infotype; //航班記錄類型</p><p> typedef struct</p><p><b> {</b></p><p> keytype keys[keylen];//關(guān)鍵字,航班號</p&g
32、t;<p> infotype others;</p><p><b> int next;</b></p><p> }slnode; //靜態(tài)鏈表類型</p><p> typedef struct</p><p><b> {</b></p&
33、gt;<p> slnode sl[maxspace];//靜態(tài)鏈表,sl[0]為頭結(jié)點(diǎn)</p><p> int keynum; //記錄當(dāng)前關(guān)鍵字字符個(gè)數(shù)</p><p> int length; //當(dāng)前表長</p><p> }sllist; //靜態(tài)鏈表類型</p>
34、<p> typedef int arrtype_n[radix_n];//十進(jìn)制數(shù)字指針</p><p> typedef int arrtype_c[radix_c];//26個(gè)字母指針</p><p> 3. 航班信息的查詢</p><p> 航班信息的查詢,可以根據(jù)不同的用戶需求采用按航班號、起點(diǎn)站、終點(diǎn)站、起飛時(shí)間、到達(dá)時(shí)間來進(jìn)行查詢,其
35、源代碼如下。</p><p> void searchcon(sllist l)</p><p><b> {</b></p><p> keytype key[keylen];</p><p> int i=1,k;</p><p> while(i>=1&&i&
36、lt;=5)</p><p><b> {</b></p><p> printf("\n ********************\n");</p><p> printf(" * 航班信息查詢系統(tǒng) *\n");</p><p> printf(" ******
37、**************\n");</p><p> printf(" * 1.航 班 號 *\n");</p><p> printf(" * 2.起 點(diǎn) 站 *\n");</p><p> printf(" * 3.終 點(diǎn) 站 *\n");</p><p>
38、 printf(" * 4.起飛時(shí)間 *\n");</p><p> printf(" * 5.到達(dá)時(shí)間 *\n");</p><p> printf(" * 0.退出系統(tǒng) *\n");</p><p> printf(" ********************\n");<
39、/p><p> printf(" 請選擇(0-5):");</p><p> scanf("%d",&i);</p><p> printf("\n");</p><p><b> switch(i)</b></p><p>
40、<b> {</b></p><p> case 1:printf("輸入要查詢的航班號(字母要大寫):");</p><p> scanf("%s",key);</p><p> k=binsearch(l,key);</p><p> printf("***
41、**********************************************************\n");</p><p><b> if(k==0)</b></p><p> printf("* 無此航班信息,可能是輸入錯(cuò)誤! *\n");</p><p><b> else&
42、lt;/b></p><p><b> {</b></p><p> printf("* 航班號 起點(diǎn)站 終點(diǎn)站 航班期 起飛時(shí)間 到達(dá)時(shí)間 機(jī)型 票價(jià) *\n");</p><p> printf("* %-8s%-7s%-6s%-11s%-9s%-7s%-5s%4d *\n",l.sl[k
43、].keys,l.sl[k].others.start,l.sl[k].others.end,l.sl[k].others.sche,l.sl[k].others.time1,l.sl[k].others.time2,l.sl[k].others.model,l.sl[k].others.price);</p><p><b> }</b></p><p> pr
44、intf("*************************************************************\n");</p><p><b> break;</b></p><p> case 2:printf("輸入要查詢的航班起點(diǎn)站名:");</p><p> sca
45、nf("%s",key);</p><p> seqsearch(l,key,i);</p><p><b> break;</b></p><p> case 3:printf("輸入要查詢的航班終點(diǎn)站名:");</p><p> scanf("%s"
46、,key);</p><p> seqsearch(l,key,i);</p><p><b> break;</b></p><p> case 4:printf("輸入要查詢的航班起飛時(shí)間:");</p><p> scanf("%s",key);</p>
47、<p> seqsearch(l,key,i);</p><p><b> break;</b></p><p> case 5:printf("輸入要查詢的航班到達(dá)時(shí)間:");</p><p> scanf("%s",key);</p><p> seqse
48、arch(l,key,i);</p><p><b> break;</b></p><p> case 0:printf("\n\n\n 再 見\n\n\n");</p><p><b> }</b></p><p><b> }</b></
49、p><p><b> }</b></p><p><b> 運(yùn)行由于測試</b></p><p><b> 六、總結(jié)與心得</b></p><p> 在本次試驗(yàn)中,遇到了很多的問題。首先,按照書上的代碼輸入后,有很多錯(cuò)誤,發(fā)現(xiàn)里面的代碼有順序不對的,有沒有定義的等問題,經(jīng)過
50、修改解決了這些問題。其次,就是在輸入時(shí)遇到了輸入不當(dāng)?shù)脝栴},修改輸入方法后得到了修改。最后,便是對幾個(gè)算法的理解不是很透徹,對算法的具體實(shí)現(xiàn)了解不深。</p><p> 針對以上問題,對各個(gè)算法解讀了還幾次,對算法的理解有了一定的理解,對整個(gè)系統(tǒng)運(yùn)行有了全面的了解。</p><p><b> 參考文獻(xiàn)</b></p><p> [1]嚴(yán)蔚
51、敏 吳偉民.數(shù)據(jù)結(jié)構(gòu)(C語言版). 北京:清華大學(xué)出版社.2007.</p><p> [2]譚浩強(qiáng).C程序設(shè)計(jì).北京:清華大學(xué)出版社.1999.12.</p><p> [3]蘇仕華.數(shù)據(jù)結(jié)構(gòu) 課程設(shè)計(jì).機(jī)械工業(yè)出版社</p><p><b> 附錄</b></p><p> #include <stdi
52、o.h></p><p> #include <string.h></p><p> #define maxspace 100</p><p> #define keylen 7</p><p> #define radix_n 10</p><p> #define radix_c 26&
53、lt;/p><p> typedef char keytype;</p><p> typedef struct </p><p><b> {</b></p><p> char start[6];</p><p> char end[6];</p><p> c
54、har sche[10];</p><p> char time1[5];</p><p> char time2[5];</p><p> char model[4];</p><p> int price;</p><p> }infotype;</p><p> typedef
55、 struct</p><p><b> {</b></p><p> keytype keys[keylen];</p><p> infotype others;</p><p><b> int next;</b></p><p><b> }sln
56、ode;</b></p><p> typedef struct</p><p><b> {</b></p><p> slnode sl[maxspace];</p><p> int keynum;</p><p> int length;</p><
57、;p><b> }sllist;</b></p><p> typedef int arrtype_n[radix_n];</p><p> typedef int arrtype_c[radix_c];</p><p> void distribute(slnode *sl,int i,arrtype_n f,arrtype_n
58、 e)</p><p><b> {</b></p><p><b> int j,p;</b></p><p> for(j=0;j<radix_n;j++)</p><p><b> {</b></p><p> f[j]=e[j]=
59、0;</p><p><b> }</b></p><p> for(p=sl[0].next;p;p=sl[p].next)</p><p><b> {</b></p><p> j=sl[p].keys[i]%48;</p><p><b> if(
60、!f[j])</b></p><p><b> f[j]=p;</b></p><p><b> else</b></p><p> sl[e[j]].next=p;</p><p><b> e[j]=p;</b></p><p>
61、<b> }</b></p><p><b> }</b></p><p> void collect(slnode *sl,int i,arrtype_n f,arrtype_n e)</p><p><b> {</b></p><p><b> int
62、 j,t;</b></p><p> for(j=0;!f[j];j++);</p><p> sl[0].next=f[j];</p><p><b> t=e[j];</b></p><p> while(j<radix_n-1)</p><p><b>
63、 {</b></p><p> for(j=j+1;j<radix_n-1&&!f[j];j++);</p><p><b> if(f[j])</b></p><p><b> {</b></p><p> sl[t].next=f[j];</p&g
64、t;<p><b> t=e[j]; </b></p><p><b> }</b></p><p><b> }</b></p><p> sl[t].next=0;</p><p><b> }</b></p>&
65、lt;p> void distribute_c(slnode *sl,int i,arrtype_c f,arrtype_c e)</p><p><b> {</b></p><p><b> int j,p;</b></p><p> for(j=0;j<radix_c;j++)</p>
66、<p><b> {</b></p><p> f[j]=e[j]=0;</p><p><b> }</b></p><p> for(p=sl[0].next;p;p=sl[p].next)</p><p><b> {</b></p>
67、<p> j=sl[p].keys[i]%65;</p><p><b> if(!f[j])</b></p><p><b> f[j]=p;</b></p><p><b> else</b></p><p> sl[e[j]].next=p;<
68、/p><p><b> e[j]=p;</b></p><p><b> }</b></p><p><b> }</b></p><p> void collect_c(slnode *sl,int i,arrtype_c f,arrtype_c e)</p>
69、<p><b> {</b></p><p><b> int j,t;</b></p><p> for(j=0;!f[j];j++);</p><p> sl[0].next=f[j];</p><p><b> t=e[j];</b></p&
70、gt;<p> while(j<radix_c-1)</p><p><b> {</b></p><p> for(j=j+1;j<radix_c-1&&!f[j];j++);</p><p><b> if(f[j])</b></p><p>&
71、lt;b> {</b></p><p> sl[t].next=f[j];</p><p><b> t=e[j]; </b></p><p><b> }</b></p><p><b> }</b></p><p> s
72、l[t].next=0;</p><p><b> }</b></p><p> void radixsort(sllist &l)//鏈?zhǔn)?lt;/p><p><b> {</b></p><p><b> int i;</b></p><p&
73、gt; arrtype_n fn,en;</p><p> arrtype_c fc,ec;</p><p> for(i=0;i<l.length;i++)</p><p> l.sl[i].next=i+1;</p><p> l.sl[l.length].next=0;</p><p> for
74、(i=l.keynum-1;i>=2;i--)</p><p><b> {</b></p><p> distribute(l.sl,i,fn,en);</p><p> collect(l.sl,i,fn,en);</p><p><b> }</b></p><
75、;p> for(i=1;i>=0;i--)</p><p><b> {</b></p><p> distribute_c(l.sl,i,fc,ec);</p><p> collect_c(l.sl,i,fc,ec);</p><p><b> }</b></p>
76、;<p><b> }</b></p><p> void arrange(sllist &l) //重新整理</p><p><b> {</b></p><p> int p,q,i;</p><p> slnode temp;</p><p
77、> p=l.sl[0].next;</p><p> for(i=1;i<l.length;i++)</p><p><b> {</b></p><p> while(p<i)</p><p> p=l.sl[p].next;</p><p> q=l.sl[p].
78、next;</p><p><b> if(p!=i)</b></p><p><b> {</b></p><p> temp=l.sl[p];</p><p> l.sl[p]=l.sl[i];</p><p> l.sl[i]=temp;</p>
79、<p> l.sl[i].next=p;</p><p><b> }</b></p><p><b> p=q;</b></p><p><b> }</b></p><p><b> }</b></p><p&
80、gt; int binsearch(sllist l,keytype key[])</p><p><b> {</b></p><p> int low,high,mid;</p><p><b> low=1;</b></p><p> high=l.length;</p>
81、<p> while(low<=high)</p><p><b> {</b></p><p> mid=(low+high)/2;</p><p> if(strcmp(key,l.sl[mid].keys)==0)</p><p> return mid;</p><
82、;p> else if(strcmp(key,l.sl[mid].keys)<0)</p><p> high=mid-1;</p><p><b> else</b></p><p> low=mid+1;</p><p><b> }</b></p><
83、p><b> return 0;</b></p><p><b> }</b></p><p> void seqsearch(sllist l,keytype key[],int i)</p><p><b> {</b></p><p> int j,k,m
84、=0;</p><p> printf("*************************************************************\n");</p><p> printf("* 航班號 起點(diǎn)站 終點(diǎn)站 航班期 起飛時(shí)間 到達(dá)時(shí)間 機(jī)型 票價(jià) *\n");</p><p> for(j=
85、1;j<=l.length;j++)</p><p><b> {</b></p><p><b> switch(i)</b></p><p><b> {</b></p><p> case 2:k=strcmp(key,l.sl[j].others.star
86、t);break;</p><p> case 3:k=strcmp(key,l.sl[j].others.end);break;</p><p> case 4:k=strcmp(key,l.sl[j].others.time1);break;</p><p> case 5:k=strcmp(key,l.sl[j].others.time2);break;
87、</p><p><b> }</b></p><p><b> if(k==0)</b></p><p><b> {</b></p><p><b> m=1;</b></p><p> printf("*
88、%-8s%-7s%-6s%-11s%-9s%-7s%-5s%4d *\n",l.sl[j].keys,l.sl[j].others.start,l.sl</p><p> [j].others.end,l.sl[j].others.sche,l.sl[j].others.time1,l.sl[j].others.time2,l.sl</p><p> [j].others.m
89、odel,l.sl[j].others.price);</p><p><b> }</b></p><p><b> }</b></p><p><b> if(m==0)</b></p><p> printf("* 無此航班信息,可能是輸入錯(cuò)誤! *\n
90、");</p><p> printf("*************************************************************\n");</p><p><b> }</b></p><p> void searchcon(sllist l)</p><
91、;p><b> {</b></p><p> keytype key[keylen];</p><p> int i=1,k;</p><p> while(i>=1&&i<=5)</p><p><b> {</b></p><p&g
92、t; printf("\********************\n");</p><p> printf(" * 航班信息查詢系統(tǒng) *\n");</p><p> printf(" ********************\n");</p><p> printf(" * 1.航
93、班 號 *\n");</p><p> printf(" * 2.起 點(diǎn) 站 *\n");</p><p> printf(" * 3.終 點(diǎn) 站 *\n");</p><p> printf(" * 4.起飛時(shí)間 *\n");</p>
94、<p> printf(" * 5.到達(dá)時(shí)間 *\n");</p><p> printf(" * 0.退出系統(tǒng) *\n");</p><p> printf(" ********************\n");</p><p> printf(" 請
95、選擇(0-5):");</p><p> scanf("%d",&i);</p><p> printf("\n");</p><p><b> switch(i)</b></p><p><b> {</b></p>
96、<p> case 1:printf("輸入要查詢的航班號(字母要大寫):");</p><p> scanf("%s",key);</p><p> k=binsearch(l,key);</p><p> printf("*************************************
97、************************\n");</p><p><b> if(k==0)</b></p><p> printf("* 無此航班信息,可能是輸入錯(cuò)誤! *\n");</p><p><b> else</b></p><p><
98、b> {</b></p><p> printf("* 航班號 起點(diǎn)站 終點(diǎn)站 航班期 起飛時(shí)間 到達(dá)時(shí)間 機(jī)型 票價(jià) *\n");</p><p> printf("* %-8s%-7s%-6s%-11s%-9s%-7s%-5s%4d *\n",l.sl[k].keys,l.sl[k].others.start,l.sl&
99、lt;/p><p> [k].others.end,l.sl[k].others.sche,l.sl[k].others.time1,l.sl[k].others.time2,l.sl</p><p> [k].others.model,l.sl[k].others.price);</p><p><b> }</b></p>
100、<p> printf("*************************************************************\n");</p><p><b> break;</b></p><p> case 2:printf("輸入要查詢的航班起點(diǎn)站名:");</p>
101、<p> scanf("%s",key);</p><p> seqsearch(l,key,i);</p><p><b> break;</b></p><p> case 3:printf("輸入要查詢的航班終點(diǎn)站名:");</p><p> scanf(
102、"%s",key);</p><p> seqsearch(l,key,i);</p><p><b> break;</b></p><p> case 4:printf("輸入要查詢的航班起飛時(shí)間:");</p><p> scanf("%s",ke
103、y);</p><p> seqsearch(l,key,i);</p><p><b> break;</b></p><p> case 5:printf("輸入要查詢的航班到達(dá)時(shí)間:");</p><p> scanf("%s",key);</p>&l
104、t;p> seqsearch(l,key,i);</p><p><b> break;</b></p><p> case 0:printf("\n\n\n 再 見\n\n\n");</p><p><b> }</b></p><p><b> }&
105、lt;/b></p><p><b> }</b></p><p> void inputdata(sllist &l)</p><p><b> {</b></p><p> int i=++l.length;</p><p> char yn=
106、39;y';</p><p> while(yn=='y'||yn=='Y')</p><p><b> {</b></p><p> printf("航班號 起點(diǎn)站 終點(diǎn)站 航班期 起飛時(shí)間 到達(dá)時(shí)間 機(jī)型 票價(jià)\n");</p><p> scanf
107、("%s%s%s%s%s%s%s%d",l.sl[i].keys,l.sl[i].others.start,l.sl[i].others.end,l.sl</p><p> [i].others.sche,l.sl[i].others.time1,l.sl[i].others.time2,l.sl[i].others.model,&l.sl</p><p>
108、 [i].others.price);</p><p> ++i; getchar(); </p><p> radixsort(l);</p><p> arrange(l);</p><p> printf("繼續(xù)輸入嗎?y/n:");</p><p> scanf("%c&
109、quot;,&yn);</p><p><b> }</b></p><p> l.length=i-1;</p><p><b> }</b></p><p> void main()</p><p><b> {</b></p
110、><p><b> sllist l;</b></p><p> l.keynum=6;</p><p> l.length=0;</p><p> inputdata(l);</p><p> searchcon(l);</p><p><b> }&l
溫馨提示
- 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)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告--航班信息查詢與檢索
- 數(shù)據(jù)結(jié)構(gòu)與算法課程設(shè)計(jì)報(bào)告——航班信息查詢系統(tǒng)(c++)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--航班管理系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)實(shí)踐環(huán)節(jié)實(shí)驗(yàn)報(bào)告(課程設(shè)計(jì))
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告(赫夫曼編碼)
- 航班售票系統(tǒng)-數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--航班信息查詢與檢索系統(tǒng)
- 06年數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)圖書管理系統(tǒng)實(shí)驗(yàn)報(bào)告
- 《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告---有關(guān)查找的操作
- 數(shù)據(jù)結(jié)構(gòu)各種排序算法的課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)(家族關(guān)系查詢系統(tǒng))
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--家族關(guān)系查詢系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-- 家族關(guān)系查詢系統(tǒng)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)avl樹實(shí)現(xiàn)及其分析實(shí)驗(yàn)報(bào)告
- 《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告--多種排序方式的比較
- 數(shù)據(jù)結(jié)構(gòu)-鄰接表存儲及遍歷-課程設(shè)計(jì)-實(shí)驗(yàn)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)-無向圖的操作-課程設(shè)計(jì)-實(shí)驗(yàn)報(bào)告
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-學(xué)生成績查詢系統(tǒng)
評論
0/150
提交評論