




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、目 錄TOC o 1-3 h u HYPERLINK l _Toc32144 一、概述 PAGEREF _Toc32144 1 HYPERLINK l _Toc13871 二、系統(tǒng)分析 PAGEREF _Toc13871 1 HYPERLINK l _Toc7774 1.航班信息的查詢與檢索 PAGEREF _Toc7774 1 HYPERLINK l _Toc24534 2.航班信息查詢與檢索數(shù)據(jù)結(jié)構(gòu)理論 PAGEREF _Toc24534 1 HYPERLINK l _Toc23760 三、概要設(shè)計(jì) PAGEREF _Toc23760 2 HYPERLINK l _Toc21361 1.系
2、統(tǒng)的功能 PAGEREF _Toc21361 2 HYPERLINK l _Toc20948 2.系統(tǒng)模塊分析及其流程圖 PAGEREF _Toc20948 3 HYPERLINK l _Toc28424 四、詳細(xì)設(shè)計(jì) PAGEREF _Toc28424 6 HYPERLINK l _Toc20675 1.各函數(shù)說(shuō)明 PAGEREF _Toc20675 6 HYPERLINK l _Toc14398 2.定義相關(guān)數(shù)據(jù)類型 PAGEREF _Toc14398 8 HYPERLINK l _Toc29112 3. 航班信息的查詢 PAGEREF _Toc29112 9 HYPERLINK l _T
3、oc29628 五、 運(yùn)行由于測(cè)試 PAGEREF _Toc29628 12 HYPERLINK l _Toc10185 六、總結(jié)與心得 PAGEREF _Toc10185 16 HYPERLINK l _Toc19719 參考文獻(xiàn) PAGEREF _Toc19719 16 HYPERLINK l _Toc2567 附錄 PAGEREF _Toc2567 16一、概述 隨著信息產(chǎn)業(yè)的飛速發(fā)展,信息化管理及查詢已經(jīng)進(jìn)入并應(yīng)用到各行各業(yè),影響著人們的價(jià)值觀念和生活方式。因此,要提高企業(yè)信息化建設(shè),利用先進(jìn)的辦公自動(dòng)化系統(tǒng)來(lái)實(shí)現(xiàn)企業(yè)內(nèi)部信息管理、共享及交流,從而提高企業(yè)綜合實(shí)力。 本次設(shè)計(jì)是針對(duì)航班
4、的查詢系統(tǒng),該設(shè)計(jì)要求對(duì)飛機(jī)航班信息進(jìn)行排序和查詢??砂春桨嗟暮桨嗵?hào)、起點(diǎn)站、終點(diǎn)站等信息進(jìn)行航班信息的查詢。二、系統(tǒng)分析1.航班信息的查詢與檢索進(jìn)入系統(tǒng)后,首先提示輸入航班的信息,包括:航班號(hào)、起點(diǎn)站、終點(diǎn)站、班期、起飛時(shí)間、到達(dá)時(shí)間、飛機(jī)型號(hào)及票價(jià)等,票價(jià)為整型,其他為字符型。當(dāng)輸入完一個(gè)信息后會(huì)提示是否繼續(xù)輸入,重復(fù)以上步驟輸入全部的信息。進(jìn)入主菜單后會(huì)給出用戶操作的界面,根據(jù)提示進(jìn)行航班信息的查詢。2.航班信息查詢與檢索數(shù)據(jù)結(jié)構(gòu)理論針對(duì)在本該類系統(tǒng)中的數(shù)據(jù)的處理情況,本系統(tǒng)采用二分查找法、基數(shù)排序法、最高位優(yōu)先法。二分查找法也稱為折半查找法,它充分利用了元素間的次序關(guān)系,采用分治策略,
5、可在最壞的情況下用O(log n)完成搜索任務(wù)。它的基本思想是,將n個(gè)元素分成個(gè)數(shù)大致相同的兩半,取an/2與欲查找的x作比較,如果x=an/2則找到x,算法終止。如 果xan/2,則我們只要在數(shù)組a的右 半部繼續(xù)搜索x。對(duì)航班號(hào)的排序是采用的基數(shù)排序法?;鶖?shù)排序法又稱“桶子法”(bucket sort)或bin sort,顧名思義,它是透過(guò)鍵值的部份資訊,將要排序的元素分配至某些“桶”中,藉以達(dá)到排序的作用,基數(shù)排序法是屬于穩(wěn)定性的排序,其時(shí)間復(fù)雜度為O (nlog(r)m),其中r為所采取的基數(shù),而m為堆數(shù),在某些時(shí)候,基數(shù)排序法的效率高于其它的比較性排序法。最高位優(yōu)先(Most Sign
6、ificant Digit first)法,簡(jiǎn)稱MSD法:先按k1排序分組,同一組中記錄,關(guān)鍵碼k1相等,再對(duì)各組按k2排序分成子組,之后,對(duì)后面的關(guān)鍵碼繼續(xù)這樣的排序分組,直到按最次位關(guān)鍵碼kd對(duì)各子組排序后。再將各組連接起來(lái),便得到一個(gè)有序序列。最低位優(yōu)先(Least Significant Digit first)法,簡(jiǎn)稱LSD法:先從kd開(kāi)始排序,再對(duì)kd-1進(jìn)行排序,依次重復(fù),直到對(duì)k1排序后便得到一個(gè)有序序列。三、概要設(shè)計(jì)1.系統(tǒng)的功能本任務(wù)要求對(duì)飛機(jī)航班信息進(jìn)行排序和查找??砂春桨嗟暮桨嗵?hào)、起點(diǎn)站、到達(dá)站、起飛時(shí)間以及到達(dá)時(shí)間等信息進(jìn)行查詢。本設(shè)計(jì)主要是對(duì)排序以及查找等概念進(jìn)行綜
7、合練習(xí)。以鏈?zhǔn)交鶖?shù)排序?yàn)橹骶€,用到二分查找和順序查找等知識(shí),還有建立靜態(tài)鏈表等相關(guān)概念。航班信息查詢系統(tǒng)航班信息查詢系統(tǒng)按航班號(hào)查詢退出系統(tǒng)輸入航班信息按起點(diǎn)站查詢按終點(diǎn)站查詢按到達(dá)時(shí)間查詢按起飛時(shí)間查詢2.系統(tǒng)模塊分析及其流程圖(1)航班排序?qū)斎胂到y(tǒng)內(nèi)的航班首先要進(jìn)行排序,我們采用的基數(shù)排序,從低位到高位依次對(duì)關(guān)鍵字進(jìn)行分配和收集,分兩段實(shí)現(xiàn)其算法流程圖。NN每段進(jìn)行串式基數(shù)排序Y開(kāi)始輸入數(shù)據(jù)數(shù)組,基數(shù)n,長(zhǎng)度Max分配收集操作輪數(shù)nT=0將數(shù)據(jù)分成P段每段n/p個(gè)nT+=1nT=Max結(jié)束 (2)時(shí)間查找根據(jù)航班的起飛時(shí)間(到達(dá)時(shí)間)查找航班的信息。開(kāi)始開(kāi)始輸入查詢時(shí)間Time=1按抵達(dá)
8、時(shí)間查詢按起飛時(shí)間查詢返回查詢信息否是(3)二分法查找功能開(kāi)始開(kāi)始輸入航班號(hào)輸入航班號(hào)對(duì)應(yīng)序號(hào)Low=highMid=(high+low)/2Low=mid+1Num=midfight numberNummidfight number返回High=mid+1否是(4)顯示功能顯示功能是將所求單詞的所有行列信息依次顯示在屏幕上。四、詳細(xì)設(shè)計(jì)1.各函數(shù)說(shuō)明1.一趟分配函數(shù)void distribute_c(slnode *sl,int i,arrtype_c f,arrtype_c e)/一趟字母分配字符函數(shù)int j,p;for(j=0;jradix_c;j+)fj=ej=0;for(p=sl0
9、.next;p;p=slp.next)j=slp.keysi%65;if(!fj)fj=p;elseslej.next=p;ej=p;2.一趟收集函數(shù)void collect_c(slnode *sl,int i,arrtype_c f,arrtype_c e)int j,t;for(j=0;!fj;j+);sl0.next=fj;t=ej;while(jradix_c-1)for(j=j+1;jradix_c-1&!fj;j+);if(fj)slt.next=fj;t=ej; slt.next=0;3.鏈?zhǔn)交鶖?shù)排序void radixsort(sllist &l)/鏈?zhǔn)交鶖?shù)排序函數(shù)int i
10、;arrtype_n fn,en;arrtype_c fc,ec;for(i=0;i=2;i-)distribute(l.sl,i,fn,en);collect(l.sl,i,fn,en);for(i=1;i=0;i-)distribute_c(l.sl,i,fc,ec);collect_c(l.sl,i,fc,ec);4.二分法查找函數(shù)int binsearch(sllist l,keytype key)int low,high,mid;low=1;high=l.length;while(low=high)mid=(low+high)/2;if(strcmp(key,l.slmid.keys
11、)=0)return mid;else if(strcmp(key,l.slmid.keys)=1&i=5)printf(n *n);printf( * 航班信息查詢系統(tǒng) *n);printf( *n);printf( * 1.航 班 號(hào) *n);printf( * 2.起 點(diǎn) 站 *n);printf( * 3.終 點(diǎn) 站 *n);printf( * 4.起飛時(shí)間 *n);printf( * 5.到達(dá)時(shí)間 *n);printf( * 0.退出系統(tǒng) *n);printf( *n);printf( 請(qǐng)選擇(0-5):);scanf(%d,&i);printf(n);switch(i)case 1
12、:printf(輸入要查詢的航班號(hào)(字母要大寫(xiě)):);scanf(%s,key);k=binsearch(l,key);printf(*n);if(k=0)printf(* 無(wú)此航班信息,可能是輸入錯(cuò)誤! *n);elseprintf(* 航班號(hào) 起點(diǎn)站 終點(diǎn)站 航班期 起飛時(shí)間 到達(dá)時(shí)間 機(jī)型 票價(jià) *n);printf(* %-8s%-7s%-6s%-11s%-9s%-7s%-5s%4d *n,l.slk.keys,l.slk.others.start,l.slk.others.end,l.slk.others.sche,l.slk.others.time1,l.slk.others.ti
13、me2,l.slk.others.model,l.slk.others.price);printf(*n);break;case 2:printf(輸入要查詢的航班起點(diǎn)站名:);scanf(%s,key);seqsearch(l,key,i);break;case 3:printf(輸入要查詢的航班終點(diǎn)站名:);scanf(%s,key);seqsearch(l,key,i);break;case 4:printf(輸入要查詢的航班起飛時(shí)間:);scanf(%s,key);seqsearch(l,key,i);break;case 5:printf(輸入要查詢的航班到達(dá)時(shí)間:);scanf(%
14、s,key);seqsearch(l,key,i);break;case 0:printf(nnn 再 見(jiàn)nnn);運(yùn)行由于測(cè)試六、總結(jié)與心得在本次試驗(yàn)中,遇到了很多的問(wèn)題。首先,按照書(shū)上的代碼輸入后,有很多錯(cuò)誤,發(fā)現(xiàn)里面的代碼有順序不對(duì)的,有沒(méi)有定義的等問(wèn)題,經(jīng)過(guò)修改解決了這些問(wèn)題。其次,就是在輸入時(shí)遇到了輸入不當(dāng)?shù)脝?wèn)題,修改輸入方法后得到了修改。最后,便是對(duì)幾個(gè)算法的理解不是很透徹,對(duì)算法的具體實(shí)現(xiàn)了解不深。針對(duì)以上問(wèn)題,對(duì)各個(gè)算法解讀了還幾次,對(duì)算法的理解有了一定的理解,對(duì)整個(gè)系統(tǒng)運(yùn)行有了全面的了解。參考文獻(xiàn)1嚴(yán)蔚敏 吳偉民.數(shù)據(jù)結(jié)構(gòu)(C語(yǔ)言版). 北京:清華大學(xué)出版社.2007.2譚浩
15、強(qiáng).C程序設(shè)計(jì).北京:清華大學(xué)出版社.1999.12.3蘇仕華.數(shù)據(jù)結(jié)構(gòu) 課程設(shè)計(jì).機(jī)械工業(yè)出版社附錄#include #include #define maxspace 100#define keylen 7#define radix_n 10#define radix_c 26typedef char keytype;typedef struct char start6;char end6;char sche10;char time15;char time25;char model4;int price;infotype;typedef structkeytype keyskeylen;i
16、nfotype others;int next;slnode;typedef structslnode slmaxspace;int keynum;int length;sllist;typedef int arrtype_nradix_n;typedef int arrtype_cradix_c;void distribute(slnode *sl,int i,arrtype_n f,arrtype_n e)int j,p;for(j=0;jradix_n;j+)fj=ej=0;for(p=sl0.next;p;p=slp.next)j=slp.keysi%48;if(!fj)fj=p;el
17、seslej.next=p;ej=p;void collect(slnode *sl,int i,arrtype_n f,arrtype_n e)int j,t;for(j=0;!fj;j+);sl0.next=fj;t=ej;while(jradix_n-1)for(j=j+1;jradix_n-1&!fj;j+);if(fj)slt.next=fj;t=ej; slt.next=0;void distribute_c(slnode *sl,int i,arrtype_c f,arrtype_c e)int j,p;for(j=0;jradix_c;j+)fj=ej=0;for(p=sl0.
18、next;p;p=slp.next)j=slp.keysi%65;if(!fj)fj=p;elseslej.next=p;ej=p;void collect_c(slnode *sl,int i,arrtype_c f,arrtype_c e)int j,t;for(j=0;!fj;j+);sl0.next=fj;t=ej;while(jradix_c-1)for(j=j+1;jradix_c-1&!fj;j+);if(fj)slt.next=fj;t=ej; slt.next=0;void radixsort(sllist &l)/鏈?zhǔn)絠nt i;arrtype_n fn,en;arrtyp
19、e_c fc,ec;for(i=0;i=2;i-)distribute(l.sl,i,fn,en);collect(l.sl,i,fn,en);for(i=1;i=0;i-)distribute_c(l.sl,i,fc,ec);collect_c(l.sl,i,fc,ec);void arrange(sllist &l) /重新整理int p,q,i;slnode temp;p=l.sl0.next;for(i=1;il.length;i+)while(pi)p=l.slp.next;q=l.slp.next;if(p!=i)temp=l.slp;l.slp=l.sli;l.sli=temp;
20、l.sli.next=p;p=q;int binsearch(sllist l,keytype key)int low,high,mid;low=1;high=l.length;while(low=high)mid=(low+high)/2;if(strcmp(key,l.slmid.keys)=0)return mid;else if(strcmp(key,l.slmid.keys)0)high=mid-1;elselow=mid+1;return 0;void seqsearch(sllist l,keytype key,int i)int j,k,m=0;printf(*n);print
21、f(* 航班號(hào) 起點(diǎn)站 終點(diǎn)站 航班期 起飛時(shí)間 到達(dá)時(shí)間 機(jī)型 票價(jià) *n);for(j=1;j=1&i=5)printf(*n);printf( * 航班信息查詢系統(tǒng) *n);printf( *n);printf( * 1.航 班 號(hào) *n);printf( * 2.起 點(diǎn) 站 *n);printf( * 3.終 點(diǎn) 站 *n);printf( * 4.起飛時(shí)間 *n);printf( * 5.到達(dá)時(shí)間 *n);printf( * 0.退出系統(tǒng) *n);printf( *n);printf( 請(qǐng)選擇(0-5):);scanf(%d,&i);printf(n);switch(i)case 1
22、:printf(輸入要查詢的航班號(hào)(字母要大寫(xiě)):);scanf(%s,key);k=binsearch(l,key);printf(*n);if(k=0)printf(* 無(wú)此航班信息,可能是輸入錯(cuò)誤! *n);elseprintf(* 航班號(hào) 起點(diǎn)站 終點(diǎn)站 航班期 起飛時(shí)間 到達(dá)時(shí)間 機(jī)型 票價(jià) *n);printf(* %-8s%-7s%-6s%-11s%-9s%-7s%-5s%4d *n,l.slk.keys,l.slk.others.start,l.slk.others.end,l.slk.others.sche,l.slk.others.time1,l.slk.others.time2,l.slk.others.model,l.slk.others.price);prin
溫馨提示
- 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ù)網(wǎng)僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 小班藝術(shù)活動(dòng)豐富孩子的創(chuàng)意計(jì)劃
- 倉(cāng)庫(kù)物流環(huán)節(jié)的協(xié)同管理計(jì)劃
- 中學(xué)教育改革計(jì)劃
- 醫(yī)保相關(guān)知識(shí)培訓(xùn)課件
- 貴州豐聯(lián)礦業(yè)有限公司普安縣久豐煤礦變更礦產(chǎn)資源綠色開(kāi)發(fā)利用方案(三合一)評(píng)審意見(jiàn)
- 《且末縣邦泰礦業(yè)投資有限公司新疆且末縣屈庫(kù)勒克東礦區(qū)金(銻)礦礦產(chǎn)資源開(kāi)發(fā)利用與生態(tài)保護(hù)修復(fù)方案》專家意見(jiàn)的認(rèn)定
- 《8 節(jié)日美食》(教學(xué)設(shè)計(jì))-2023-2024學(xué)年五年級(jí)下冊(cè)綜合實(shí)踐活動(dòng)皖教版
- 如何改善個(gè)人責(zé)任意識(shí)提升組織效率
- 第三單元第十三課《使用電子郵件和QQ》-教學(xué)設(shè)計(jì) 2023-2024學(xué)年粵教版(2019)初中信息技術(shù)七年級(jí)上冊(cè)
- 2025年粘土主題組合創(chuàng)意標(biāo)準(zhǔn)教案
- 二年級(jí)下冊(cè)語(yǔ)文神州謠部編版課件
- 消毒供應(yīng)中心清洗消毒滅菌技術(shù)操作規(guī)范
- BIM在鋼結(jié)構(gòu)工程中應(yīng)用
- 職業(yè)健康安全交底
- GB∕T 7588.1-2020 電梯制造與安裝安全規(guī)范 第1部分:乘客電梯和載貨電梯
- 壓力容器定期(月度)檢查記錄
- 無(wú)線電遙控模型飛機(jī)戴氏教學(xué)法(業(yè)余特技飛行訓(xùn)練)
- 2022年全省公訴業(yè)務(wù)知識(shí)考試參考答案
- 天潤(rùn)化肥事故案例警示會(huì)3.5
- 小學(xué)語(yǔ)文總復(fù)習(xí)指導(dǎo)(課堂PPT)
- 鎮(zhèn)政府(街道辦事處)辦公大樓平面圖
評(píng)論
0/150
提交評(píng)論