數(shù)據(jù)結(jié)構(gòu)課程設(shè)計---二叉樹的遍歷算法集成_第1頁
已閱讀1頁,還剩21頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p><b>  數(shù)據(jù)結(jié)構(gòu)</b></p><p><b>  課程設(shè)計說明書</b></p><p>  題目: 二叉樹的遍歷算法集成 </p><p>  院 系: 計算機科學(xué)與工程學(xué)院</p><p>  專業(yè)班級: <

2、/p><p>  學(xué) 號: </p><p>  學(xué)生姓名: </p><p>  指導(dǎo)教師: </p><p>  2010年1月11日</p><p>  課程設(shè)計(論文)任務(wù)書<

3、/p><p>  計算機科學(xué)與工程 學(xué)院 計算機軟件教研室</p><p>  2009年 11 月 16 日 </p><p><b>  目  錄</b></p><p><b>  1、需求分析1</b></

4、p><p><b>  2、概要設(shè)計2</b></p><p>  2.1 功能設(shè)計2</p><p>  2.2 算法流程圖3</p><p><b>  3、詳細(xì)設(shè)計4</b></p><p>  3.1 界面設(shè)計4</p><p>  3.

5、2 詳細(xì)代碼分析5</p><p>  3.3 調(diào)試分析14</p><p>  3.3.1調(diào)試結(jié)果14</p><p>  3.3.2算法分析18</p><p><b>  4、總結(jié)18</b></p><p><b>  參考文獻19</b></p&g

6、t;<p><b>  1、需求分析</b></p><p>  數(shù)據(jù)結(jié)構(gòu)是計算機、信息管理、信息與計算機科學(xué)等信息類專業(yè)最重要的專業(yè)基礎(chǔ)課程,掌握好數(shù)據(jù)結(jié)構(gòu)的知識將直接關(guān)系到后續(xù)專業(yè)課程的學(xué)習(xí)。數(shù)據(jù)結(jié)構(gòu)只要研究四個方面的問題:(1)數(shù)據(jù)的邏輯結(jié)構(gòu),即數(shù)據(jù)之間的邏輯關(guān)系;(2)數(shù)據(jù)的物理結(jié)構(gòu),即數(shù)據(jù)在計算機內(nèi)的存儲方式;(3)對數(shù)據(jù)的加工,即基于某種存儲方式的操作算法;(4)算

7、法的分析;即評價算法的優(yōu)劣。</p><p>  本實驗是用鏈?zhǔn)酱鎯Y(jié)構(gòu)來存儲二叉樹并進行一系列的算法,且結(jié)點內(nèi)容的數(shù)據(jù)類型為字符型。</p><p>  本程序用VC++6.0編寫,可以實現(xiàn)各種二叉樹的遍歷。包括先序遍歷、中序遍歷、后序遍歷的遞歸算法,先序遍歷、中序遍歷、后序遍歷的非遞歸算法以及 能查找任一結(jié)點在某種遍歷序列中的前驅(qū)和后繼。</p><p>  根

8、據(jù)題目知,程序主要是根據(jù)給定二叉樹的先序遍歷結(jié)果,構(gòu)造出二叉樹并輸出按中,后序遍歷的結(jié)果,以及求二叉樹的葉子個數(shù)等。其中二叉樹的結(jié)點用字符表示。</p><p>  (1) 先創(chuàng)建二叉樹:按先序次序輸入,構(gòu)造二叉鏈表表示的二叉樹。</p><p>  (2)設(shè)計算法:先序遍歷,中序遍歷,后序遍歷. 在做到層序遍歷時,應(yīng)注意算法如下:根結(jié)點入隊,隊頭元素出隊,左孩子不為空入隊右孩子不為空入隊

9、的順序進行。</p><p>  (3)可以加入求二叉樹的深度二叉樹的葉子數(shù)二叉樹的結(jié)點總數(shù)等一些簡單的算法 。</p><p>  (4) 設(shè)計main()函數(shù)調(diào)用以上步驟實現(xiàn)相關(guān)功能。</p><p><b>  2、概要設(shè)計</b></p><p><b>  2.1 功能設(shè)計</b><

10、/p><p> ?。?)typedef struct BTNode</p><p>  定義一個用鏈?zhǔn)酱鎯Y(jié)構(gòu)存儲的二叉樹,其中包括左孩子和右孩子以及數(shù)據(jù)元素的內(nèi)容。和單鏈表類似,一個二叉鏈表由頭指針唯一確定,若二叉樹為空,則頭指針指向空。并且結(jié)點內(nèi)容的數(shù)據(jù)類型為字符型。</p><p> ?。?)CreateBiTree(BiTree &T)</p>

11、;<p>  此函數(shù)的功能是構(gòu)建二叉樹。從鍵盤上按先序次序輸入字符構(gòu)造二叉鏈表表示的二叉樹T,其中用星號表示空樹 。</p><p>  (3)NRPreOrder(BiTree bt) </p><p>  此函數(shù)的功能是用非遞歸的方法實現(xiàn)二叉樹的先序遍歷算法。調(diào)用此函數(shù)可以獲得二叉樹的非遞歸的先序遍歷的結(jié)果。</p><p>  (4)NRInOr

12、der(BiTree bt)</p><p>  此函數(shù)的功能是用非遞歸的方法實現(xiàn)二叉樹的中序遍歷算法。調(diào)用此函數(shù)可以獲得二叉樹的非遞歸的中序遍歷的結(jié)果。</p><p> ?。?)NRPostOrder(BiTree bt)</p><p>  此函數(shù)的功能是用非遞歸的方法實現(xiàn)二叉樹的后序遍歷算法。調(diào)用此函數(shù)可以獲得二叉樹的非遞歸的后序遍歷的結(jié)果。其中bt是要遍歷

13、樹的根指針,后序遍歷要求在遍歷完左右子樹后,再訪問根。需要判斷根結(jié)點的左右子樹是否均遍歷過??刹捎脴?biāo)記法,結(jié)點入棧時,配一個標(biāo)志tag一同入棧1:遍歷左子樹的現(xiàn)場保護,2:遍歷右子樹前的現(xiàn)場保護。首先將bt和tag(為1)入棧,遍歷左子樹;返回后,修改棧頂tag為2,遍歷右子樹;最后訪問根結(jié)點。</p><p> ?。?)PreOrderTraverse(BiTree T) </p><p&g

14、t;  函數(shù)功能是用遞歸的方法對二叉樹進行先序遍歷,調(diào)用此函數(shù)可以獲得二叉樹的遞歸的先序遍歷的結(jié)果。</p><p> ?。?)InOrderTraverse(BiTree T)</p><p>  函數(shù)功能是用遞歸的方法對二叉樹進行中序遍歷,調(diào)用此函數(shù)可以獲得二叉樹的遞歸的中序遍歷的結(jié)果。</p><p>  (8)PostOrderTraverse(BiTree

15、 T)</p><p>  函數(shù)功能是用遞歸的方法對二叉樹進行后序遍歷,調(diào)用此函數(shù)可以獲得二叉樹的遞歸的后序遍歷的結(jié)果。</p><p>  (9)LevelOrderTraverse(BiTree T)</p><p>  調(diào)用此函數(shù)可以獲得二叉樹的層序遍歷。</p><p> ?。?0)BTDepth(BiTree T)</p>

16、;<p>  求二叉樹的深度的算法。</p><p>  (11)Leaf(BiTree T)</p><p>  求二叉樹的葉子數(shù)的算法。</p><p> ?。?2)NodeCount(BiTree T)</p><p>  求二叉樹的結(jié)點總數(shù)的算法。</p><p> ?。?3)main()<

17、/p><p>  主函數(shù)用while()與switch(select)語句對二叉樹的操作的算法進行了設(shè)計??梢詫崿F(xiàn)以上函數(shù)的功能,并能退出程序。</p><p><b>  2.2 算法流程圖</b></p><p>  先設(shè)計出二叉樹的一些算法的函數(shù),如非遞歸遍歷、遞歸遍歷、層次遍歷等一些算法。然后在主函數(shù)中逐一調(diào)用。其中,在求任意結(jié)點在中序遍歷

18、前驅(qū)后繼算法時利用了遞歸的中序遍歷的算法。</p><p>  算法流程圖如圖1所示。</p><p><b>  圖 1 算法流程圖</b></p><p><b>  3、詳細(xì)設(shè)計</b></p><p><b>  3.1 界面設(shè)計</b></p><

19、p>  設(shè)計的界面如圖2所示。</p><p><b>  圖2 界面</b></p><p>  3.2 詳細(xì)代碼設(shè)計</p><p><b> ?。?)定義二叉樹</b></p><p>  用鏈?zhǔn)酱鎯Y(jié)構(gòu)存儲二叉樹。其中,Lchild和Rchild是分別指向該結(jié)點左孩子和右孩子的指針,d

20、ata是數(shù)據(jù)元素的內(nèi)容。定義二叉樹結(jié)點值的類型為字符型且結(jié)點個數(shù)不超過10個。</p><p>  typedef char ElemType;</p><p>  //結(jié)點個數(shù)不超過10個</p><p>  const int MaxLength=10;</p><p>  typedef struct BTNode{</p>

21、<p>  ElemType data;</p><p>  struct BTNode *lchild,*rchild;</p><p>  }BTNode,* BiTree;(2)查找模塊</p><p><b> ?。?)構(gòu)造二叉鏈表</b></p><p>  創(chuàng)建二叉鏈表存儲的二叉樹。按二叉樹帶空

22、指針的先序次序輸入結(jié)點值,結(jié)點類型為字符型。按先序次序輸入,其中*表示空結(jié)點。算法是按照先序遍歷思想設(shè)計的。構(gòu)造二叉鏈表表示的二叉樹T,星號表示空樹。</p><p>  void CreateBiTree(BiTree &T){</p><p><b>  char ch;</b></p><p>  ch=getchar();<

23、;/p><p>  if(ch=='*') T=NULL;</p><p><b>  else{</b></p><p>  if(!(T=(BTNode *)malloc(sizeof(BTNode)))) cout<<"malloc fail!";</p><p>  T

24、->data=ch;</p><p>  CreateBiTree(T->lchild);</p><p>  CreateBiTree(T->rchild);</p><p><b>  }</b></p><p><b>  }</b></p><p>

25、 ?。?)非遞歸的先序遍歷算法</p><p>  函數(shù)功能是用非遞歸的方法對二叉樹進行先序遍歷。通過分析可知最后處理過的結(jié)點的右子樹應(yīng)該首先被訪問,最先處理過的結(jié)點的右子樹應(yīng)該最后被訪問,顯然使用??梢越鉀Q問題。</p><p>  void NRPreOrder(BiTree bt)</p><p>  {BiTree stack[MaxLength],p;&

26、lt;/p><p><b>  int top;</b></p><p>  if (bt!=NULL){</p><p>  top=0;p=bt;</p><p>  while(p!=NULL||top>0)</p><p>  {while(p!=NULL)</p>&l

27、t;p><b>  {</b></p><p>  cout<<p->data<<' ';</p><p>  stack[top]=p; </p><p><b>  top++;</b></p><p>  p=p->lchild;

28、</p><p><b>  }</b></p><p>  if (top>0)</p><p>  { top--;p=stack[top];p=p->rchild;}</p><p><b>  }</b></p><p><b>  

29、}</b></p><p><b>  }</b></p><p>  (4)非遞歸的中序遍歷算法</p><p>  此函數(shù)的功能是用非遞歸的方法實現(xiàn)二叉樹的中序遍歷算法。調(diào)用此函數(shù)可以獲得二叉樹的非遞歸的中序遍歷的結(jié)果。用非遞歸調(diào)用也得使用棧。</p><p>  void NRInOrder(BiTre

30、e bt)</p><p>  {BiTree stack[MaxLength],p;</p><p><b>  int top;</b></p><p>  if (bt!=NULL){</p><p>  top=0;p=bt;</p><p>  while(p!=NULL||top&g

31、t;0)</p><p>  {while(p!=NULL)</p><p><b>  {</b></p><p>  stack[top]=p; </p><p><b>  top++;</b></p><p>  p=p->lchild;</p&

32、gt;<p><b>  }</b></p><p>  if (top>0)</p><p>  { top--;p=stack[top];cout<<p->data<<' ';p=p->rchild;}</p><p><b>  }</b>

33、;</p><p><b>  }</b></p><p><b>  }</b></p><p> ?。?)非遞歸的后序遍歷算法</p><p>  此函數(shù)的功能是用非遞歸的方法實現(xiàn)二叉樹的后序遍歷算法。調(diào)用此函數(shù)可以獲得二叉樹的非遞歸的后序遍歷的結(jié)果。其中bt是要遍歷樹的根指針,后序遍歷要求在遍

34、歷完左右子樹后,再訪問根。需要判斷根結(jié)點的左右子樹是否均遍歷過??刹捎脴?biāo)記法,結(jié)點入棧時,配一個標(biāo)志tag一同入棧1:遍歷左子樹的現(xiàn)場保護,2:遍歷右子樹前的現(xiàn)場保護。首先將bt和tag(為1)入棧,遍歷左子樹;返回后,修改棧頂tag為2,遍歷右子樹;最后訪問根結(jié)點。</p><p>  typedef struct </p><p><b>  {</b></

35、p><p>  BiTree ptr;</p><p><b>  int tag;</b></p><p>  }stacknode;</p><p>  void NRPostOrder(BiTree bt)</p><p><b>  {</b></p>&l

36、t;p>  stacknode s[MaxLength],x;</p><p>  BiTree p=bt;</p><p><b>  int top;</b></p><p>  if(bt!=NULL){ </p><p>  top=0;p=bt;</p><p><b&g

37、t;  do </b></p><p><b>  {</b></p><p>  while (p!=NULL) </p><p><b>  {</b></p><p>  s[top].ptr = p; </p><p>  s[top].ta

38、g = 1; </p><p><b>  top++;</b></p><p>  p=p->lchild;</p><p><b>  } </b></p><p>  while (top>0 && s[top-1].tag==2) <

39、/p><p><b>  {</b></p><p>  x = s[--top];</p><p>  p = x.ptr;</p><p>  cout<<p->data<<' '; </p><p><b>  }

40、 </b></p><p>  if (top>0)</p><p><b>  {</b></p><p>  s[top-1].tag =2; </p><p>  p=s[top-1].ptr->rchild; </p><p><b&

41、gt;  } </b></p><p>  }while (top>0);}</p><p><b>  }</b></p><p> ?。?)遞歸的先序遍歷</p><p>  函數(shù)功能是用遞歸的方法對二叉樹進行先序遍歷,調(diào)用此函數(shù)可以獲得二叉樹的遞歸的先序遍歷的結(jié)果。算法思想:若二叉樹為空,則

42、結(jié)束遍歷操作;否則訪問根結(jié)點;先序遍歷根的左子樹;先序遍歷根的右子樹。</p><p>  void PreOrderTraverse(BiTree T){</p><p><b>  if(T){</b></p><p>  cout<<T->data<<' ';</p><p

43、>  PreOrderTraverse(T->lchild);</p><p>  PreOrderTraverse(T->rchild);</p><p><b>  }</b></p><p><b>  }</b></p><p>  (7)遞歸的中序遍歷</p>

44、<p>  函數(shù)功能是用遞歸的方法對二叉樹進行中序遍歷。算法思想:若二叉樹為空,則結(jié)束遍歷操作;否則中序遍歷根的左子樹;訪問根結(jié)點;中序遍歷根的右子樹。</p><p>  void InOrderTraverse(BiTree T){</p><p><b>  if(T){</b></p><p>  InOrderTrave

45、rse(T->lchild);</p><p>  cout<<T->data<<' ';</p><p>  a[i]=T->data;</p><p><b>  i++;</b></p><p>  InOrderTraverse(T->rchild)

46、;</p><p><b>  }</b></p><p><b>  }</b></p><p> ?。?)遞歸的后序遍歷</p><p>  函數(shù)功能是用遞歸的方法對二叉樹進行中序遍歷。算法思想:若二叉樹為空,則結(jié)束遍歷操作;否則后序遍歷根的左子樹;后序遍歷根的右子樹;訪問根結(jié)點。</p&

47、gt;<p>  void PostOrderTraverse(BiTree T){</p><p><b>  if(T){</b></p><p>  PostOrderTraverse(T->lchild);</p><p>  PostOrderTraverse(T->rchild);</p>&

48、lt;p>  cout<<T->data<<' ';</p><p><b>  }</b></p><p><b>  }</b></p><p><b> ?。?)層序遍歷</b></p><p>  調(diào)用此函數(shù)可以獲得二

49、叉樹的層序遍歷。該算法的思想如下:訪問根結(jié)點,并將該結(jié)點記錄下來;若記錄的所有節(jié)點都已經(jīng)處理完畢,則結(jié)束遍歷操作;否則重復(fù)下列操作。取出記錄中第一個還沒有訪問孩子的結(jié)點,若它有左孩子,則訪問做孩子,并記錄下來;若它有右孩子,則訪問右孩子,并記錄下來。</p><p>  void LevelOrderTraverse(BiTree T){</p><p>  BiTree Q[MaxLen

50、gth];</p><p>  int front=0,rear=0;</p><p><b>  BiTree p;</b></p><p><b>  //根結(jié)點入隊</b></p><p><b>  if(T){ </b></p><p>  Q

51、[rear]=T;</p><p>  rear=(rear+1)%MaxLength;</p><p><b>  } </b></p><p>  while(front!=rear){</p><p><b>  //隊頭元素出隊</b></p><p>  p=Q[f

52、ront]; </p><p>  front=(front+1)%MaxLength; </p><p>  cout<<p->data<<' ';</p><p>  //左孩子不為空,入隊</p><p>  if(p->lchild){ </p><p>

53、;  Q[rear]=p->lchild;</p><p>  rear=(rear+1)%MaxLength;</p><p><b>  }</b></p><p>  //右孩子不為空,入隊</p><p>  if(p->rchild){ </p><p>  Q[rear]=

54、p->rchild;</p><p>  rear=(rear+1)%MaxLength;</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p> ?。?0)結(jié)點在中

55、序遍歷的前驅(qū)后繼</p><p>  此程序所用的方法并非利用線索二叉樹。對整個二叉樹進行中序遍歷,看看哪個結(jié)點之后是所求結(jié)點的前驅(qū),則該結(jié)點就是所求結(jié)點的中序前驅(qū)。同樣的也可以得到中序后繼。</p><p>  int i;char a[100];</p><p>  void InOrderTraverse(BiTree T){</p><p

56、><b>  if(T){</b></p><p>  InOrderTraverse(T->lchild);</p><p>  cout<<T->data<<' ';</p><p>  a[i]=T->data;</p><p><b>  

57、i++;</b></p><p>  InOrderTraverse(T->rchild);</p><p><b>  }</b></p><p><b>  }</b></p><p>  上面是利用的二叉樹的中序遍歷方法來獲得結(jié)點的信息,再調(diào)用下面語句便可實現(xiàn)以上功能。在主函

58、數(shù)中應(yīng)用switch()語句。</p><p>  cout<<"\n請輸入您要在中序中查找前驅(qū)后繼的結(jié)點(字符型):\n";</p><p><b>  cin>>c;</b></p><p>  for(j=0;j<i;j++)</p><p><b>  

59、{</b></p><p>  if(a[j]==c)</p><p>  cout<<"結(jié)點的前驅(qū)為:\n"<<a[j-1]<<endl<<"結(jié)點的后繼為:\n"<<a[j+1]; </p><p><b>  }</b&

60、gt;</p><p><b>  break;</b></p><p><b>  3.3 調(diào)試分析</b></p><p><b>  3.3.1調(diào)試結(jié)果</b></p><p><b>  (1)系統(tǒng)界面</b></p><p&g

61、t;  系統(tǒng)主界面如圖3所示。</p><p><b>  圖 3 主界面</b></p><p><b>  (2) 創(chuàng)建二叉樹</b></p><p>  創(chuàng)建后的二叉樹如圖4所示。</p><p><b>  圖 4創(chuàng)建二叉樹</b></p><p&g

62、t; ?。?)二叉樹的非遞歸遍歷算法(前、中、后)</p><p>  非遞歸遍歷如圖5所示。</p><p>  圖 5二叉樹的非遞歸遍歷算法(前、中、后)</p><p> ?。?)二叉樹的遞歸遍歷算法(前、中、后)</p><p>  遞歸遍歷如圖6所示。</p><p>  圖 6二叉樹的遞歸遍歷算法(前、中、

63、后)</p><p>  (5)二叉樹的層次遍歷算法</p><p>  層次遍歷如圖7所示。</p><p>  圖 7 二叉樹的層次遍歷算法</p><p> ?。?)求二叉樹的深度</p><p>  創(chuàng)建后的二叉樹的深度如圖8所示。</p><p>  圖 8求二叉樹的深度</p&

64、gt;<p>  (7)求二叉樹的葉子結(jié)點</p><p>  求出的結(jié)點的個數(shù)如圖9所示。</p><p>  圖 9求二叉樹的葉子結(jié)點</p><p> ?。?)求二叉樹的結(jié)點總數(shù)</p><p>  求出的結(jié)點總數(shù)如圖10所示。</p><p>  圖 10求二叉樹的結(jié)點總數(shù)</p>

65、<p> ?。?)求結(jié)點在中序遍歷的前驅(qū)后繼</p><p>  任意一結(jié)點的前驅(qū)后繼如圖11所示。</p><p>  圖 11求結(jié)點在中序遍歷的前驅(qū)后繼</p><p><b>  3.3.2算法分析</b></p><p>  本程序按遞歸遍歷所耗費的時間復(fù)雜度為O(n),其所耗費的空間復(fù)雜度也為O(n)

66、。</p><p><b>  4、總結(jié) </b></p><p>  雖然都說“程序=數(shù)據(jù)結(jié)構(gòu)+算法”,但我在學(xué)習(xí)運用數(shù)據(jù)結(jié)構(gòu)編程之前,并沒能深刻體會到這一點,直到這次課設(shè)實踐。我感受最深的一點是:以前用C編程,只是注重如何編寫函數(shù)能夠完成所需要的功能,似乎沒有明確的戰(zhàn)術(shù),只是憑單純的意識和簡單的語句來堆砌出一段程序。感覺有點像張飛打仗,有勇無謀,只要能完成任務(wù)就

67、行。</p><p>  但現(xiàn)在編程感覺完全不同了。在編寫一個程序之前,自己能夠綜合考慮各種因素,首先選取自己需要的數(shù)據(jù)結(jié)構(gòu),是樹還是圖或是別的什么?然后選定一種或幾種存儲結(jié)構(gòu)來具體的決定后面的函數(shù)的主要風(fēng)格。最后在編寫每一個函數(shù)之前,可以仔細(xì)斟酌比對,挑選出最適合當(dāng)前狀況的算法。這樣,即使在完整的程序還沒有寫出來之前,自己心中已經(jīng)有了明確的原圖了。這樣無形中就提高了自己編寫的程序的質(zhì)量。</p>

68、<p>  另外,我還體會到深刻理解數(shù)據(jù)結(jié)構(gòu)的重要性。只有真正理解這樣定義數(shù)據(jù)類型的好處,才能用好這樣一種數(shù)據(jù)結(jié)構(gòu)。了解典型數(shù)據(jù)結(jié)構(gòu)的性質(zhì)是非常有用的,它往往是編寫程序的關(guān)鍵。我以前對遞歸算法一直很害怕,總是看不明白究竟這遞歸是怎么進行的。在這次實驗中我終于克服了這一障礙,一次次單步執(zhí)行書中遞歸函數(shù)的例子,并一遍遍在心中自己默默的走,終于弄明白了,真的是功夫不負(fù)有心人?。⊥瑫r我還根據(jù)自己的理解寫出了類似的遞歸函數(shù)實現(xiàn)了新的功能

69、,真是受益良多??!在這次實驗中,我對參數(shù)的調(diào)用也進行了很多種嘗試,已差不多經(jīng)能夠選擇合適的參數(shù)形式來實現(xiàn)函數(shù)之間的數(shù)據(jù)傳輸交互了。</p><p>  這次實驗中我也出現(xiàn)過一些比較嚴(yán)重的錯誤。在用鏈表結(jié)構(gòu)編寫程序時我錯誤的把一個定義的一級指針用二級指針來做,結(jié)果出現(xiàn)了一些難以想象的后果。這是我對基本概念理解的模糊不清造成的。后來在同學(xué)的指點下我意識到自己的錯誤。不過收獲也很不少。至少我又掌握了指針的應(yīng)用,??傊?,

70、我會繼續(xù)我的興趣編寫程序的,相信在越來越多的嘗試之后,自己會不斷進步不斷提高的。</p><p><b>  參考文獻</b></p><p>  [1] 秦鋒. 數(shù)據(jù)結(jié)構(gòu)(C語言版).合肥:中國科學(xué)技術(shù)大學(xué)出版社,2007 </p><p>  [2] 溫秀梅.Visual C++面象對象程序設(shè)計教程與實驗.北京:清華大學(xué)出版社2006<

溫馨提示

  • 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論