數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---車廂調(diào)度_第1頁
已閱讀1頁,還剩13頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、<p>  課 程 設(shè) 計(jì)</p><p><b> ?。〝?shù)據(jù)結(jié)構(gòu))</b></p><p><b>  二○一一年一月十日</b></p><p>  課程設(shè)計(jì)任務(wù)書及成績評定</p><p> ?、?、題目的目的和要求: </p><p>  鞏固和加深對數(shù)

2、據(jù)結(jié)構(gòu)的理解,通過上機(jī)實(shí)驗(yàn)、調(diào)試程序,加深對課本知識的理解,最終使學(xué)生能夠熟練應(yīng)用數(shù)據(jù)結(jié)構(gòu)的知識寫程序。</p><p>  (1)通過本課程的學(xué)習(xí),能熟練掌握幾種基本數(shù)據(jù)結(jié)構(gòu)的基本操作。</p><p> ?。?)能針對給定題目,選擇相應(yīng)的數(shù)據(jù)結(jié)構(gòu),分析并設(shè)計(jì)算法,進(jìn)而給出問題的正確求解過程并編寫代碼實(shí)現(xiàn)。</p><p> ?、?、設(shè)計(jì)進(jìn)度及完成情況</p&

3、gt;<p> ?、?、主要參考文獻(xiàn)及資料</p><p>  [1] 嚴(yán)蔚敏 數(shù)據(jù)結(jié)構(gòu)(C語言版)清華大學(xué)出版社 1999</p><p>  [2] 嚴(yán)蔚敏 數(shù)據(jù)結(jié)構(gòu)題集(C語言版)清華大學(xué)出版社 1999</p><p>  [3] 譚浩強(qiáng) C語言程序設(shè)計(jì) 清華大學(xué)出版社</p><p>  [4] 與所用編程環(huán)境相配套

4、的C語言或C++相關(guān)的資料</p><p><b>  Ⅳ、成績評定:</b></p><p>  設(shè)計(jì)成績: (教師填寫)</p><p>  指導(dǎo)老師: (簽字)</p><p>  二○一一 年 一 月 十 日</p><

5、p><b>  目 錄</b></p><p>  第一章 概述……………………………………………………………1</p><p>  第二章 系統(tǒng)分析………………………………………………………2</p><p>  第三章 概要設(shè)計(jì)………………………………………………………</p><p>  第四章 詳細(xì)設(shè)計(jì)…

6、……………………………………………………</p><p>  第五章 運(yùn)行與測試……………………………………………………</p><p>  第六章 總結(jié)與心得……………………………………………………</p><p>  參考文獻(xiàn)………………………………………………………………</p><p><b>  第一章 概述</b&

7、gt;</p><p>  課程設(shè)計(jì)是實(shí)踐性教學(xué)中的一個重要環(huán)節(jié),它以某一課程為基礎(chǔ),可以涉及和課程相關(guān)的各個方面,是一門獨(dú)立于課程之外的特殊課程。課程設(shè)計(jì)是讓同學(xué)們對所學(xué)的課程更全面的學(xué)習(xí)和應(yīng)用,理解和掌握課程的相關(guān)知識?!稊?shù)據(jù)結(jié)構(gòu)》是一門重要的專業(yè)基礎(chǔ)課,是計(jì)算機(jī)理論和應(yīng)用的核心基礎(chǔ)課程。</p><p>  數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì),要求學(xué)生在數(shù)據(jù)結(jié)構(gòu)的邏輯特性和物理表示、數(shù)據(jù)結(jié)構(gòu)的選擇和應(yīng)

8、用、算法的設(shè)計(jì)及其實(shí)現(xiàn)等方面,加深對課程基本內(nèi)容的理解。同時(shí),在程序設(shè)計(jì)方法以及上機(jī)操作等基本技能和科學(xué)作風(fēng)方面受到比較系統(tǒng)和嚴(yán)格的訓(xùn)練。</p><p>  在這次的課程設(shè)計(jì)中我選擇的題目是車廂調(diào)度。首先在教科書3.1.2節(jié)中提供的棧的順序存儲結(jié)構(gòu)SqStack之上實(shí)現(xiàn)棧的基本操作,即實(shí)現(xiàn)棧的類型。程序?qū)5娜魏未嫒。锤模x取和狀態(tài)判別等操作)必須借助于基本操作進(jìn)行。一般的說,在操作過程的任何狀態(tài)下都有兩種

9、可能的操作:“入”和“出”。每個狀態(tài)下處理問題的發(fā)發(fā)是相同的,這說明問題本身具有天然的遞歸性,可以參考用遞歸的算法實(shí)現(xiàn)。輸入序列可以僅由一對整型變量表示,即給出序列頭/尾編號。輸出序列用棧實(shí)現(xiàn)是方便的,只要再定義一個棧打印操作print(s),自低至頂順序地印出棧元素的值。</p><p>  本部分主要說明:課程設(shè)計(jì)的目的意義;對自己題目的問題描述;以上為樣例,特別是字體,字號,行間距等均參照樣例,以下同。&l

10、t;/p><p><b>  第二章 系統(tǒng)分析</b></p><p><b>  1.問題分析:</b></p><p>  可假設(shè)對二叉樹的n個結(jié)點(diǎn)從1到n編號,且令其先序序列為1,2,……,n,則不同的二叉樹所得到的中序序列不同。這樣,不同形態(tài)的二叉樹的數(shù)目正好是先序序列均為1,2,……,n的二叉樹所能得到的中序序列的數(shù)

11、目,而中序遍歷的過程實(shí)際上是一個結(jié)點(diǎn)進(jìn)棧和出棧的過程。因此,序列1,2,……,n按不同順序進(jìn)棧和出棧所能得到的排列的數(shù)目正好是由先序序列為1,2,……,n所能得到的中序序列的數(shù)目,也就是先序序列為1,2,……,n的不同形態(tài)的二叉樹的數(shù)目,其數(shù)目為 :</p><p>  1 (2n)!</p><p>  Cn== ------ * -------

12、-</p><p>  n+1 n!*n!</p><p><b>  2.設(shè)計(jì)內(nèi)容:</b></p><p>  現(xiàn)有n節(jié)車廂,按不同的順序進(jìn)棧和出棧,計(jì)算出所有的出棧序列并輸出。</p><p>  例如:有4節(jié)車廂則輸出:</p><p>  4 3 2 1</p&

13、gt;<p>  2 3 4 1</p><p><b>  3 4 2</b></p><p>  3 4 2 1</p><p>  2 3 1 4</p><p>  1 3 2 4</p><p>  3 2 1 4</p>&

14、lt;p>  2 1 4 3</p><p>  1 2 4 3</p><p>  3 2 1 4</p><p>  2 1 3 4</p><p>  1 2 3 4</p><p>  2 4 3 1</p><p>  1 4 3 2&l

15、t;/p><p>  本部主要說明題目的基本要求,注意對題目的基本要求進(jìn)行詳細(xì)分析,盡量細(xì)化到程序中每個函數(shù)實(shí)現(xiàn)的功能都能在此處說明。</p><p><b>  第三章 概要設(shè)計(jì)</b></p><p>  1.設(shè)定棧的抽象數(shù)據(jù)類型定義:</p><p>  ADT Stack {</p><p>

16、  數(shù)據(jù)對象:D={∈CharSet,i=1,2,...,n,,n≥0}</p><p>  數(shù)據(jù)關(guān)系:R1={<∈D,i=2,...,n}</p><p><b>  基本操作:</b></p><p>  InitStack(&S)</p><p>  操作結(jié)果:構(gòu)造一個空棧S。</p>

17、<p>  DestroyStack(&S)</p><p>  初始條件:棧S已存在。</p><p>  操作結(jié)果:銷毀棧S。</p><p>  ClearStack(&S)</p><p>  初始條件:棧S已存在。</p><p>  操作結(jié)果:將棧S清為空棧。</p>

18、<p>  StackLength(S)</p><p>  初始條件:棧S已存在。</p><p>  操作結(jié)果:返回棧S的長度。</p><p>  StackEmpty(S)</p><p>  初始條件:棧S已存在。</p><p>  操作結(jié)果:若S為空棧,則返回TURE,否則返回FALSE。&l

19、t;/p><p>  GetTop(S,&e)</p><p>  初始條件:棧S已存在。</p><p>  操作結(jié)果:若S不空,則e返回棧頂元素。</p><p>  Push(&S,&e)</p><p>  初始條件:棧S已存在。</p><p>  操作結(jié)果:在s的

20、棧頂插入新的棧頂元素e。</p><p>  Pop(&S,&e)</p><p>  初始條件:棧S已存在。</p><p>  操作結(jié)果:刪除S的棧頂元素,并以e返回其值。</p><p>  StackTraverse(S,visit())</p><p>  初始條件:棧S已存在。</p&

21、gt;<p>  操作結(jié)果:從棧底到棧頂依次對S中的每個元素調(diào)用函數(shù)visit()。</p><p>  }ADT Stack</p><p>  2.本程序包含兩個模塊</p><p><b>  1)主程序模塊:</b></p><p>  Void main()</p><p>

22、;<b>  {</b></p><p><b>  初始化;</b></p><p><b>  For循環(huán)}</b></p><p>  2)棧模塊——實(shí)現(xiàn)棧的抽象數(shù)據(jù)類型</p><p>  各模塊之間的調(diào)用關(guān)系如下:</p><p><b

23、>  主程序模塊</b></p><p><b>  棧模塊</b></p><p><b>  本章主要介紹</b></p><p>  1、數(shù)據(jù)結(jié)構(gòu)的設(shè)計(jì) </p><p>  主要介紹在實(shí)驗(yàn)中采用(或設(shè)計(jì))的數(shù)據(jù)結(jié)構(gòu)以及原因。</p><p><

24、b>  2、算法的設(shè)計(jì)</b></p><p>  主要說明本設(shè)計(jì)從總體上劃分幾個模塊,每個模塊需要完成的功能是什么?定義每個模塊對應(yīng)的函數(shù)接口,用偽代碼(類C或C++)設(shè)計(jì)每個模塊對應(yīng)的算法。</p><p>  3、抽象數(shù)據(jù)類型的 設(shè)計(jì)</p><p>  根據(jù)所設(shè)計(jì)的數(shù)據(jù)結(jié)構(gòu)和接口函數(shù),寫出抽象數(shù)據(jù)類型定義或者簡單類定義。</p>

25、<p><b>  第四章 詳細(xì)設(shè)計(jì)</b></p><p><b>  1)棧類型;</b></p><p>  typedef struct stacklist</p><p><b>  {</b></p><p>  SElemType *base;<

26、;/p><p>  SElemType *top;</p><p>  int stacksize;</p><p><b>  }SqStack;</b></p><p>  棧的基本操作設(shè)置如下:</p><p>  void Stack_init(SqStack *s)//初始化,設(shè)s為空棧&l

27、t;/p><p>  void Stack_Push(SqStack *s,SElemType e)//若分配空間成功,則在s的棧頂插入新的元素e,并返回TRUE</p><p>  //若棧不變,并返回FALSE</p><p>  SElemType Stack_Pop(SqStack *s)</p><p>  Status Stack_E

28、mpty(SqStack *s)</p><p>  Status Stack_Full(SqStack *s)</p><p>  void Stack_printreverse(SqStack s)</p><p>  void search(SqStack *inputPoint,SqStack *tempPoint,SqStack *outputPoint)

29、</p><p><b>  2)代碼</b></p><p>  #include <iostream> </p><p>  using namespace std;</p><p>  typedef int SElemType;</p><p>  typedef int St

30、atus;</p><p>  int end;/*最后一個車廂的號碼*/</p><p>  long total=0;/*總的組合方案數(shù)目*/</p><p>  typedef struct stacklist</p><p><b>  {</b></p><p>  SElemType

31、*base;</p><p>  SElemType *top;</p><p>  int stacksize;</p><p><b>  }SqStack;</b></p><p>  void Stack_init(SqStack *s)</p><p><b>  {</

32、b></p><p>  s->base=(SElemType *)malloc(end*sizeof(int));</p><p>  if(!s->base) exit(0);</p><p>  s->top=s->base;</p><p>  s->stacksize=end;</p>

33、<p><b>  }</b></p><p>  void Stack_Push(SqStack *s,SElemType e)</p><p><b>  {</b></p><p>  *(s->top)++=e;</p><p><b>  }</b>

34、;</p><p>  SElemType Stack_Pop(SqStack *s)</p><p><b>  {</b></p><p>  if(s->top==s->base)</p><p><b>  return 0;</b></p><p>  

35、return *(--(s->top));</p><p><b>  }</b></p><p>  Status Stack_Empty(SqStack *s)</p><p><b>  {</b></p><p>  if(s->top==s->base)</p>

36、;<p><b>  return 1;</b></p><p><b>  return 0;</b></p><p><b>  }</b></p><p>  Status Stack_Full(SqStack *s)</p><p><b>  

37、{</b></p><p>  if(s->top-s->base==end)</p><p><b>  return 1;</b></p><p><b>  return 0;</b></p><p><b>  }</b></p>

38、<p>  void Stack_printreverse(SqStack s)</p><p><b>  {</b></p><p><b>  int *po;</b></p><p>  po=s.base;</p><p>  printf("\t[%ld]: &quo

39、t;,total);</p><p>  for(;po!=s.top;) </p><p>  printf("%d ",*po++);</p><p>  printf("\n");</p><p><b>  }</b></p><p>  void

40、search(SqStack *inputPoint,SqStack *tempPoint,SqStack *outputPoint)</p><p><b>  {</b></p><p>  if(!Stack_Empty(inputPoint))</p><p><b>  {</b></p><

41、p>  Stack_Push(tempPoint,Stack_Pop(inputPoint));</p><p>  search(inputPoint,tempPoint,outputPoint);</p><p>  Stack_Push(inputPoint,Stack_Pop(tempPoint));</p><p><b>  }</

42、b></p><p>  if(!Stack_Empty(tempPoint))</p><p><b>  {</b></p><p>  Stack_Push(outputPoint,Stack_Pop(tempPoint));</p><p>  search(inputPoint,tempPoint,out

43、putPoint);</p><p>  Stack_Push(tempPoint,Stack_Pop(outputPoint));</p><p><b>  }</b></p><p>  if(Stack_Full(outputPoint))</p><p><b>  {</b></p

44、><p><b>  total++;</b></p><p>  Stack_printreverse(*outputPoint);</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  主函

45、數(shù):</b></p><p>  void main()</p><p><b>  {</b></p><p>  SqStack input,temp,output;</p><p><b>  int i;</b></p><p>  printf(&quo

46、t;\n\n\t\t\t\t車廂調(diào)度\n");</p><p>  printf("\n\t請輸入車廂長度: ");</p><p>  scanf("%d",&end);</p><p>  /*初始化三個棧*/</p><p>  Stack_init(&input);&l

47、t;/p><p>  Stack_init(&temp);</p><p>  Stack_init(&output);</p><p>  /*將車廂號碼進(jìn)棧*/</p><p>  for(i=end;i>=1;i--)</p><p>  Stack_Push(&input,i);<

48、;/p><p>  search(&input,&temp,&output);</p><p><b>  }</b></p><p>  設(shè)計(jì)抽象數(shù)據(jù)類型對應(yīng)的類定義。(如用C實(shí)現(xiàn)則沒有這項(xiàng))</p><p><b>  設(shè)計(jì)每個成員函數(shù);</b></p><

49、;p><b>  設(shè)計(jì)主函數(shù)</b></p><p><b>  第五章 運(yùn)行與測試</b></p><p><b>  輸入3,結(jié)果如下:</b></p><p><b>  輸入4,結(jié)果如下:</b></p><p><b>  第六章

50、 總結(jié)與心得</b></p><p>  通過對本學(xué)期的數(shù)據(jù)結(jié)構(gòu)課程的學(xué)習(xí),我完成了本次的課程設(shè)計(jì)報(bào)告,其中得到了很多的體會,也了解到很多的知識點(diǎn)。我明白了課程設(shè)計(jì)是大學(xué)教育中一個重要的實(shí)踐教學(xué)環(huán)節(jié)。在課程設(shè)計(jì)過程中,我根據(jù)具體設(shè)計(jì)題目,運(yùn)用自己所學(xué)的知識,獨(dú)立地進(jìn)行設(shè)計(jì)和實(shí)驗(yàn)。除了鞏固、加深和融合自己所學(xué)的數(shù)據(jù)結(jié)構(gòu)專業(yè)課程知識外,更重要的是培養(yǎng)了我多方面的能力,如獨(dú)立思考能力、綜合設(shè)計(jì)能力、實(shí)踐動手

51、能力、開拓創(chuàng)新能力、自學(xué)能力、文獻(xiàn)檢索能力等等。通過這次的課程設(shè)計(jì),我也了解到自己所學(xué)的一些不足之處,以及一些還不了解的知識點(diǎn),以后會加強(qiáng)學(xué)習(xí),把不懂的弄懂</p><p><b>  參考文獻(xiàn):</b></p><p>  [1] 嚴(yán)蔚敏、吳偉民主編 《數(shù)據(jù)結(jié)構(gòu)》(C語言版) 清華大學(xué)出版社 2002</p><p>  [2] 殷

52、人昆等著 《數(shù)據(jù)結(jié)構(gòu)》(C++版) 清華大學(xué)出版社 2001</p><p>  [3] 金遠(yuǎn)平著 《數(shù)據(jù)結(jié)構(gòu)》(C++描述) 清華大學(xué)出版社 2005 </p><p>  [4] 許卓群等著 《數(shù)據(jù)結(jié)構(gòu)與算法》 高等教育出版社 2004</p><p>  [5]

溫馨提示

  • 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

提交評論