數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告--航班信息查詢與檢索_第1頁
已閱讀1頁,還剩14頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、<p>  《數(shù)據(jù)結(jié)構(gòu)》課程設(shè)計(jì)報(bào)告書</p><p><b>  姓名: </b></p><p><b>  性別: </b></p><p><b>  班級:</b></p><p><b>  學(xué)號:</b></p>&l

2、t;p><b>  日期:</b></p><p>  一、 課程設(shè)計(jì)題目:航班信息查詢與檢索</p><p>  二、 課程設(shè)計(jì)內(nèi)容: </p><p>  1、設(shè)計(jì)一個(gè)航班信息查詢與檢索系統(tǒng),每個(gè)航班記錄包括:航班號、起始站、終點(diǎn)站、起飛時(shí)間、到達(dá)時(shí)間、有效期。</p><p><b>  2、要有輸

3、入模塊。</b></p><p>  3、對航班信息進(jìn)行排序與查找。</p><p><b>  三、 算法設(shè)計(jì):</b></p><p><b>  設(shè)計(jì)思路:</b></p><p>  根據(jù)題目要求,程序必須實(shí)現(xiàn)航班信息的錄入和查詢。程序首先定義一個(gè)用于儲存航班信息的數(shù)據(jù)類型,再由

4、用戶錄入航班數(shù)據(jù),在錄入的同時(shí)并對數(shù)據(jù)進(jìn)行基數(shù)排序,最后執(zhí)行數(shù)據(jù)查詢和檢索。在查詢設(shè)計(jì)中,使用折半查找法對排好序的航班數(shù)據(jù)按航班號實(shí)現(xiàn)快速查找,按起點(diǎn)站、終點(diǎn)站、起飛時(shí)間、到達(dá)時(shí)間查找的則采用順序查詢方法。用到了文件的一般概念。</p><p>  主要算法流程圖如下:</p><p>  四、 程序正確性驗(yàn)證(指邊界測試數(shù)據(jù),即程序?qū)τ诰倪x擇的典型、苛刻而帶有刁難性的幾組輸入數(shù)據(jù)能夠得

5、出滿足要求的結(jié)果)</p><p>  截取的程序運(yùn)行情況如下圖所示</p><p>  五、 課程設(shè)計(jì)過程中出現(xiàn)的主要問題、原因及解決方法:</p><p>  首先是要實(shí)現(xiàn)所要的功能需用什么數(shù)據(jù)結(jié)構(gòu)的問題,比如排序問題究竟用那一種,在同學(xué)的幫助下和上網(wǎng)搜尋資料,采用基數(shù)排序最符合,程序無法運(yùn)行 ,最后在大家的努力下一起修改錯誤使得程序可以正常運(yùn)行。</p&

6、gt;<p>  六、 課程設(shè)計(jì)的主要收獲:</p><p>  1、 通過這次課程設(shè)計(jì)使我對平時(shí)課上所學(xué)的知識有了更加深刻的理解,增加了熟練應(yīng)用的程度,對解決問題的思路和算法設(shè)計(jì)思想有了更深刻的認(rèn)識,解決問題的思路是關(guān)鍵。</p><p>  2、 這次課程設(shè)計(jì)使我看到了自身還存在著很多不足,對與一些基本的問題掌握的不是很扎實(shí),在設(shè)計(jì)過程中平添了不少麻煩。要繼續(xù)對知識進(jìn)行鞏

7、固,加深印象。</p><p>  3、 遇到問題要積極與同學(xué)或者是老師進(jìn)行溝通,這樣能夠少走不少彎路。</p><p>  4、 以后不管是做什么應(yīng)定要用心才能做好,不能偷工減料。</p><p>  七、 對今后課程設(shè)計(jì)的建議:</p><p>  1、 今后的課程設(shè)計(jì)可以更加貼近于生活,貼近于現(xiàn)實(shí),提高我們把書上學(xué)到的知識應(yīng)用到現(xiàn)實(shí)生

8、活中的能力,以及在現(xiàn)實(shí)社會中遇到問題的解決能力。</p><p>  2、可以變換一種方式,減少或者是杜絕同學(xué)鉆空子和偷工減料的機(jī)會。</p><p><b>  附錄(源程序代碼)</b></p><p>  #include <iostream.h></p><p>  #include <stri

9、ng.h></p><p>  #include <iomanip.h></p><p>  #include <fstream.h></p><p>  #define MAXSIZE 50</p><p>  typedef struct{</p><p><b>  int

10、 hour;</b></p><p>  int minute;</p><p><b>  }time;</b></p><p>  typedef struct{</p><p><b>  int year;</b></p><p>  int month;

11、</p><p><b>  int day;</b></p><p><b>  }date;</b></p><p>  typedef struct information</p><p><b>  {</b></p><p>  char nu

12、mber[7]; //航班號</p><p>  time start; //起點(diǎn)站</p><p>  time end; //終點(diǎn)站</p><p>  char start_station[16]; //起飛時(shí)間</p><p>  char end_station[16]; //到達(dá)時(shí)間</p

13、><p>  date date_1; //有效期</p><p>  date date_2;</p><p>  information *next;</p><p><b>  }info;</b></p><p>  void screen()</p><p>

14、<b>  {</b></p><p>  cout<<" 【航班信息的查詢與檢索】"<<endl;</p><p>  cout<<" ★*******************************★"<<endl;</

15、p><p>  cout<<" 1.插入航班信息 "<<endl;</p><p>  cout<<" 2.按起終點(diǎn)查詢 "<<endl;</p><p>  cout<<"

16、 3.按出行日期查詢 "<<endl;</p><p>  cout<<" 4.按航班號進(jìn)行查詢"<<endl;</p><p>  cout<<" ★*******************************★"<<en

17、dl;</p><p><b>  }</b></p><p>  void Init_info(info *info_1[],int &count)</p><p><b>  {</b></p><p>  fstream iofile("hangban.txt",i

18、os::in|ios::out|ios::binary);</p><p><b>  while(1)</b></p><p><b>  {</b></p><p>  info_1[count]=new info;</p><p>  iofile.read((char*)info_1[cou

19、nt],sizeof(info));</p><p>  if(iofile.eof())break;</p><p>  if(count) info_1[count-1]->next=info_1[count];</p><p>  info_1[count]->next=NULL;</p><p><b>  co

20、unt++;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  void insert_info(info *info_1[],int &count)</p><p><b>  {</b></

21、p><p>  info_1[count]=new info;</p><p>  cout<<"航班號:";</p><p>  cin>>info_1[count]->number;</p><p>  cout<<"起點(diǎn)站:";</p><

22、p>  cin>>info_1[count]->start_station;</p><p>  cout<<"終點(diǎn)站:";</p><p>  cin>>info_1[count]->end_station;</p><p>  cout<<"起飛時(shí)間(時(shí) 分):&qu

23、ot;;</p><p>  cin>>info_1[count]->start.hour>>info_1[count]->start.minute;</p><p>  cout<<"到達(dá)時(shí)間(時(shí) 分):";</p><p>  cin>>info_1[count]->end.h

24、our>>info_1[count]->end.minute;</p><p>  cout<<"有效期(年 月 日 年 月 日):";</p><p>  cin>>info_1[count]->date_1.year>>info_1[count]->date_1.month>>info_1

25、[count]->date_1.day</p><p>  >>info_1[count]->date_2.year>>info_1[count]->date_2.month>>info_1[count]->date_2.day;</p><p>  if(count) info_1[count-1]->next=info_

26、1[count];</p><p>  info_1[count]->next=NULL;</p><p><b>  count++;</b></p><p><b>  }</b></p><p>  void distribute(info *info_1[],info *info_2[

27、],info *info_3[],int count,int state)</p><p><b>  {</b></p><p>  for(int i=0;i<26;i++)</p><p><b>  {</b></p><p>  info_2[i]=NULL;</p>

28、<p>  info_3[i]=NULL;</p><p><b>  }</b></p><p>  for(int j=0;j<count;j++)</p><p><b>  {</b></p><p>  int value;</p><p>  if

29、('a'<=info_1[j]->number[state])</p><p>  value=info_1[j]->number[state]-'a';</p><p><b>  else</b></p><p>  value=info_1[j]->number[state]-

30、9;0';</p><p>  if(!info_2[value])</p><p><b>  {</b></p><p>  info_2[value]=info_1[j];</p><p>  info_3[value]=info_1[j];</p><p><b>  }

31、</b></p><p><b>  else</b></p><p><b>  {</b></p><p>  info_3[value]->next=info_1[j];</p><p>  info_3[value]=info_1[j];</p><p&

32、gt;<b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  void collect(info *info_1[],info *info_2[],info *info_3[])</p><p><b&g

33、t;  {</b></p><p>  for(int i=0,j=0;i<26;i++)</p><p><b>  {</b></p><p>  while(info_2[i])</p><p><b>  {</b></p><p>  info_1

34、[j++]=info_2[i];</p><p>  if(info_2[i]==info_3[i]) break;</p><p>  info_2[i]=info_2[i]->next;</p><p><b>  }</b></p><p><b>  }</b></p>

35、<p><b>  }</b></p><p>  void radix(info *info_1[],info *info_2[],info *info_3[],int count)</p><p><b>  {</b></p><p>  for(int i=strlen(info_1[0]->num

36、ber)-1;0<=i;i--)</p><p><b>  {</b></p><p>  distribute(info_1,info_2,info_3,count,i);</p><p>  collect(info_1,info_2,info_3);</p><p><b>  }</b&g

37、t;</p><p><b>  }</b></p><p>  int bin_search(info *info_1[],char *str,int low,int high)</p><p><b>  {</b></p><p><b>  int mid;</b>&l

38、t;/p><p>  while(low<=high)</p><p><b>  {</b></p><p>  mid=(low+high)/2;</p><p>  if(!strcmp(info_1[mid]->number,str))</p><p>  return mid;&

39、lt;/p><p>  if(strcmp(info_1[mid]->number,str)<0)</p><p>  low=mid+1;</p><p><b>  else</b></p><p>  high=mid-1;</p><p><b>  }</b>

40、;</p><p>  return (-1);</p><p><b>  }</b></p><p>  void print(info *info_1[],int state)</p><p><b>  {</b></p><p>  cout<<&quo

41、t;航班號:"<<info_1[state]->number<<endl;</p><p>  cout<<"起點(diǎn)站-->終點(diǎn)站:"<<info_1[state]->start_station<<"-->"<<info_1[state]->end_station&

42、lt;<endl;</p><p>  cout<<"起飛時(shí)間-->到達(dá)時(shí)間:"<<info_1[state]->start.hour<<":"<<info_1[state]->start.minute</p><p>  <<"-->"&l

43、t;<info_1[state]->end.hour<<":"<<info_1[state]->end.minute<<endl;</p><p>  cout<<"有效期:"<<info_1[state]->date_1.year<<"."</p>

44、;<p>  <<info_1[state]->date_1.month<<"."<<info_1[state]->date_1.day</p><p>  <<"-->"<<info_1[state]->date_1.year<<"."<

45、/p><p>  <<info_1[state]->date_2.month<<"."<<info_1[state]->date_2.day<<endl;</p><p><b>  }</b></p><p>  int *serach_adress(info *in

46、fo_1[],char str_1[],char str_2[],int count)</p><p><b>  {</b></p><p>  int *data;</p><p>  data=new int[count+1];</p><p>  for(int i=0,j=0;i<count;i++)&l

47、t;/p><p><b>  {</b></p><p>  if(!strcmp(info_1[i]->start_station,str_1)&&!strcmp(info_1[i]->end_station,str_2))</p><p><b>  {</b></p><p

48、>  print(info_1,i);</p><p>  data[++j]=i;</p><p><b>  }</b></p><p><b>  }</b></p><p>  data[0]=j;</p><p>  cout<<"共有&

49、quot;<<data[0]<<"個(gè)記錄?。?!"<<endl;</p><p>  return data;</p><p><b>  }</b></p><p>  void search_date(info *info_1[],int data[],int data_1,int da

50、ta_2,int data_3,int count)</p><p><b>  {</b></p><p>  int i,j,k,m=0;</p><p>  int value_1,value_2,value_3;</p><p>  if(data) k=data[0];</p><p>

51、  else k=count;</p><p>  for(i=0;i<k;i++)</p><p><b>  {</b></p><p>  if(data) j=data[i+1];</p><p><b>  else j=i;</b></p><p>  va

52、lue_1=(info_1[j]->date_1.year-2000)*12*30+info_1[j]->date_1.month*30+info_1[j]->date_1.day;</p><p>  value_2=(info_1[j]->date_2.year-2000)*12*30+info_1[j]->date_2.month*30+info_1[j]->date_2

53、.day;</p><p>  value_3=(data_1-2000)*12*30+data_2*30+data_3;</p><p>  if(value_1<=value_3&&value_3<=value_2)</p><p><b>  {</b></p><p>  print(

54、info_1,j);</p><p><b>  m++;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  cout<<"共有"<<m<<"個(gè)記錄!?。?/p>

55、"<<endl;</p><p><b>  }</b></p><p>  void main()</p><p><b>  {</b></p><p>  int count=0;</p><p><b>  int i;</b&g

56、t;</p><p>  int data_1,data_2,data_3,data_4=1,data_5,*data;</p><p>  char str_1[16],str_2[16];</p><p>  info *info_1[MAXSIZE],*info_2[26],*info_3[26];</p><p>  Init_inf

57、o(info_1,count);</p><p>  radix(info_1,info_2,info_3,count);</p><p><b>  screen();</b></p><p><b>  while(1)</b></p><p><b>  {</b><

58、;/p><p>  char flag;</p><p>  cout<<"歡迎進(jìn)入本系統(tǒng)請選者所要進(jìn)行的操作:";</p><p>  cin>>flag;</p><p>  switch(flag)</p><p><b>  {</b></p&

59、gt;<p><b>  case '1':</b></p><p>  insert_info(info_1,count);</p><p>  radix(info_1,info_2,info_3,count);</p><p><b>  break;</b></p>&l

60、t;p><b>  case '2':</b></p><p>  cout<<"請輸入起點(diǎn)站,終點(diǎn)站:";</p><p>  cin>>str_1>>str_2;</p><p>  data=serach_adress(info_1,str_1,str_2,co

61、unt);</p><p>  if(!data[0]) break;</p><p>  cout<<"是否繼續(xù)按出行日期查詢(Y/N):";</p><p>  cin>>flag;</p><p>  if(flag=='N'||flag=='n') break

62、;</p><p>  cout<<setfill('*')<<setw(81)<<endl;</p><p><b>  data_4=0;</b></p><p><b>  case '3':</b></p><p>  co

63、ut<<"請輸入出行日期(年 月 日):";</p><p>  cin>>data_1>>data_2>>data_3;</p><p>  if(data_4) data=NULL;</p><p>  search_date(info_1,data,data_1,data_2,data_3,c

64、ount);</p><p><b>  break;</b></p><p><b>  case '4':</b></p><p>  cout<<"請輸入航班號:";</p><p>  cin>>str_1;</p>

65、<p>  data_5=bin_search(info_1,str_1,0,count-1);</p><p>  if(data_5==-1)</p><p><b>  {</b></p><p>  cout<<"無記錄?。?!"<<endl;</p><p>

66、<b>  break;</b></p><p><b>  }</b></p><p>  print(info_1,data_5);</p><p><b>  break;</b></p><p><b>  case '0':</b>

67、;</p><p><b>  {</b></p><p>  fstream iofile("hangban.txt",ios::in|ios::out|ios::binary);</p><p>  for(i=0;i<count;i++)</p><p><b>  {</

68、b></p><p>  iofile.write((char*)info_1[i],sizeof(info));</p><p><b>  }</b></p><p><b>  return;</b></p><p><b>  }</b></p>&

69、lt;p><b>  default:</b></p><p>  cout<<"輸入錯誤!??!"<<endl;</p><p><b>  }</b></p><p><b>  }</b></p><p><b>

溫馨提示

  • 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)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論