課程設(shè)計報告---文章編輯、猴子選大王、建立二叉樹、拓撲排序、各種排序_第1頁
已閱讀1頁,還剩23頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p><b>  課程設(shè)計</b></p><p>  2009 ~ 2010學(xué)年第二學(xué)期</p><p>  設(shè)計題目 文章編輯、猴子選大王、建立二叉樹、拓撲排序、各種排序 </p><p><b>  目錄</b></p><

2、;p>  1、目的與要求2</p><p>  2、課程設(shè)計內(nèi)容說明3</p><p>  2.1主菜單界面:3</p><p>  2.2項目一:文章編輯**3</p><p>  2.3項目二:猴子選大王**4</p><p>  2.4項目三:建立二叉樹,層序、先序遍歷**6<

3、/p><p>  2.5項目四:拓撲排序8</p><p>  2.6項目五:各種排序:插入排序和改進冒泡排序算法10</p><p>  5、結(jié)論及體會14</p><p><b>  6、附錄14</b></p><p><b>  目的與要求</b><

4、/p><p>  鞏固和加深對常見數(shù)據(jù)結(jié)構(gòu)的理解和掌握</p><p>  掌握基于數(shù)據(jù)結(jié)構(gòu)進行算法設(shè)計的基本方法</p><p>  掌握用高級語言實現(xiàn)算法的基本技能</p><p>  掌握書寫程序設(shè)計說明文檔的能力</p><p>  提高運用數(shù)據(jù)結(jié)構(gòu)知識及高級語言解決非數(shù)值實際問題的能力</p>&l

5、t;p><b>  課程設(shè)計內(nèi)容說明</b></p><p><b>  主菜單界面:</b></p><p>  項目一:文章編輯**</p><p> ?。?)功能:輸入一頁文字,程序可以統(tǒng)計出文字、數(shù)字、空格的個數(shù)。</p><p>  靜態(tài)存儲一頁文章,每行最多不超過80個字符,共N行

6、;要求(1)分別統(tǒng)計出其中英文字母數(shù)和空格數(shù)及整篇文章總字數(shù);(2)統(tǒng)計某一字符串在文章中出現(xiàn)的次數(shù),并輸出該次數(shù);(3)刪除某一子串,并將后面的字符前移。</p><p>  存儲結(jié)構(gòu)使用線性表,分別用幾個子函數(shù)實現(xiàn)相應(yīng)的功能;</p><p>  輸入數(shù)據(jù)的形式和范圍:可以輸入大寫、小寫的英文字母、任何數(shù)字及標點符號。</p><p>  輸出形式:(1)分行輸

7、出用戶輸入的各行字符;(2)分4行輸出"全部字母數(shù)"、"數(shù)字個數(shù)"、"空格個數(shù)"、"文章總字數(shù)"(3)輸出刪除某一字符串后的文章;</p><p>  (2)程序的輸入輸出描述:</p><p><b>  進入應(yīng)用程序:</b></p><p><b>

8、 ?。?)輸入文章:</b></p><p><b> ?。?)查找:</b></p><p> ?。?)刪除:原文為:QuYing111,刪除Y后為:Quing111</p><p>  (4)尚未解決的問題或改進方向</p><p>  這個文章編輯的缺點在于無法統(tǒng)計空格數(shù),只能夠統(tǒng)計大小寫字母以及數(shù)字&

9、lt;/p><p> ?。?)對軟件的使用說明</p><p>  在CFree4.0下打開軟件,進行操作</p><p>  項目二:猴子選大王**</p><p>  對設(shè)計任務(wù)內(nèi)容的概述</p><p>  一堆猴子都有編號,編號是1,2,3 ...m ,這群猴子(m個)按照1-m的順序圍坐一圈,從第1開始數(shù),每數(shù)到

10、第N個,該猴子就要離開此圈,這樣依次下來,直到圈中只剩下最后一只猴子,則該猴子為大王。</p><p><b>  需求分析或功能描述</b></p><p>  輸入數(shù)據(jù):輸入m,n m,n 為整數(shù),n<m</p><p>  輸出形式:中文提示按照m個猴子,數(shù)n 個數(shù)的方法,輸出為大王的猴子是幾號 ,建立一個函數(shù)來實現(xiàn)此功能。<

11、/p><p><b>  程序輸入輸出描述:</b></p><p><b>  開始程序:</b></p><p><b>  部分程序代碼:</b></p><p>  #define MaxSize 50</p><p>  int houzi(int

12、 n,int m)</p><p><b>  {</b></p><p>  int p[MaxSize];</p><p>  int i,j,t;</p><p>  for(i=0;i<n;i++)</p><p><b>  p[i]=i+1;</b><

13、/p><p><b>  t=0;</b></p><p>  printf("\n出列順序:");</p><p>  for(i=n;i>=1;i--)</p><p><b>  {</b></p><p>  t=(t+m-1)%i;</p

14、><p>  printf("%d",p[t]);</p><p>  for(j=t+1;j<=i-1;j++)</p><p>  p[j-1]=p[j];</p><p>  } printf("\n");</p><p>  printf("\n故編號 %d

15、 的猴子是大王!\n",p[t]);</p><p>  printf("\n");</p><p><b>  }</b></p><p>  項目三:建立二叉樹,層序、先序遍歷**</p><p> ?。?)對設(shè)計任務(wù)內(nèi)容的概述</p><p>  要求能夠輸入樹

16、的各個結(jié)點,并能夠輸出用不同方法遍歷的遍歷序列;分別建立建立二叉樹存儲結(jié)構(gòu)的的輸入函數(shù)、輸出層序遍歷序列的函數(shù)、輸出先序遍歷序列的函數(shù);</p><p>  (2)需求分析或功能描述</p><p>  程序功能包括,建立二叉樹,輸出二叉樹,對二叉樹進行層次遍歷和先序遍歷。</p><p> ?。?)概要設(shè)計或程序流程圖</p><p>  

17、進入程序,選擇菜單,1創(chuàng)建二叉樹,在程序中進行構(gòu)造二叉樹,并輸出創(chuàng)建好的二叉樹,2層次遍歷二叉樹,輸出二叉樹的層次遍歷序列,3先序遍歷二叉樹,輸出二叉樹的先序遍歷序列。</p><p> ?。?)詳細設(shè)計或源代碼說明</p><p>  創(chuàng)建二叉樹CreateBTNode(*b,*str)。根據(jù)二叉樹括號表示的字符串*str生成對應(yīng)的二叉鏈存儲結(jié)構(gòu),用ch掃描采用括號表示法表示二叉樹的字符

18、串。輸出二叉樹,以括號表示法輸出一棵二叉樹。先序遍歷二叉樹的過程是,訪問根結(jié)點,先序遍歷左子樹,先序遍歷右子樹。層次遍歷的過程是,先將根結(jié)點進隊,在隊不為空時循環(huán),從隊列中出列一個結(jié)點*p,訪問它,若它有左孩子結(jié)點,如此操作直到隊空為止。 </p><p> ?。?)程序模塊及其接口描述</p><p>  typedef char ElemType;</p><p&g

19、t;  typedef struct node</p><p><b>  {</b></p><p>  ElemType data;//數(shù)據(jù)元素 </p><p>  struct node *lchild;//指向左孩子 </p><p>  struct node *rchild;//指向右孩子 </p&g

20、t;<p><b>  }BTNode;</b></p><p>  void CreateBTNode(BTNode *&b,char *str)//由str串創(chuàng)建二叉鏈</p><p>  void DispBTNode(BTNode *b)//以括號表示法輸出二叉樹</p><p>  void TravLevel

21、(BTNode *b)//層次遍歷</p><p>  void PreOrder(BTNode *b)//先序遍歷的遞歸算法</p><p> ?。?)程序的輸入與輸出描述</p><p><b>  輸入界面:</b></p><p><b>  輸出界面:</b></p><

22、;p> ?。?)調(diào)試分析或程序測試</p><p> ?。?)尚未解決的問題或改進方向</p><p>  因為本程序最終要與其他兩個程序合并在一起,在主界面進行選擇。所以在進入主界面時要在本程序的主函數(shù)處修改字符,否則在調(diào)用本程序時主函數(shù)會發(fā)生沖突。</p><p> ?。?)對軟件的使用說明</p><p>  在CFree4.0下

23、打開軟件,進行操作。</p><p><b>  項目四:拓撲排序</b></p><p>  對設(shè)計任務(wù)內(nèi)容的概述</p><p>  編寫函數(shù),實現(xiàn)圖的拓撲排序。</p><p><b>  需求分析或功能描述</b></p><p>  在一個有向圖中找一個拓撲序列的過

24、程稱為拓撲排序,而每一個有向圖的拓撲序列并不唯一,本程序的功能就是將用戶輸入的序列進行拓撲排序。</p><p>  概要設(shè)計或程序流程圖</p><p>  在程序菜單中選擇開始,輸入有向圖的結(jié)點數(shù)和邊數(shù),此時程序就會輸出結(jié)點信息,如v1,v2,v3等,接下來會要求用戶輸入第一條邊的起點和終點,通過程序運行就可以輸出拓撲排序結(jié)果。</p><p>  詳細設(shè)計或源

25、代碼說明</p><p>  對于給定的有向圖,采用鄰接表作為存儲結(jié)構(gòu),為每個頂點設(shè)置一個鏈表,每個鏈表有一個表頭結(jié)點,這些表頭結(jié)點構(gòu)成一個數(shù)組,表頭結(jié)點中增加一個存放頂點入度的域count,在執(zhí)行拓撲排序的過程中,當(dāng)某個頂點的入度為0(沒有前驅(qū)結(jié)點時),就將此頂點輸出,同時將該頂點的所有后繼結(jié)點的入度減1,為了避免重復(fù)檢測入度為0的頂點,設(shè)立一個棧St,以存放入度為0的頂點。</p><p&

26、gt;  程序模塊及其接口描述</p><p>  typedef struct</p><p><b>  {</b></p><p>  int *base; //棧底 </p><p>  int *top; //棧頂 </p>

27、;<p>  int stacksize; //??臻g </p><p><b>  }Stack;</b></p><p>  int InitStack(Stack &s) //創(chuàng)建一個空棧</p><p>  int Push(Stack &s,int e)

28、 //進棧</p><p>  bool Empty(Stack s) //查看棧是否為空</p><p>  int Pop(Stack &s) //出棧</p><p>  int LocateVex(Graph G,int v) //返回節(jié)點v在圖中的位置</p&

29、gt;<p>  void CreateGraph(Graph &G) //建圖 </p><p>  void TopologicalSort(Graph G) //拓撲排序函數(shù)</p><p>  程序的輸入與輸出描述</p><p><b>  輸入界面:</b></p><p>

30、;  再輸入結(jié)點數(shù)和邊數(shù),此時會輸出頂點信息:</p><p><b>  排序結(jié)果輸出界面:</b></p><p><b>  調(diào)試分析或程序測試</b></p><p><b>  對軟件的使用說明</b></p><p>  在CFree4.0下打開軟件,進行操作。&l

31、t;/p><p>  項目五:各種排序:插入排序和改進冒泡排序算法</p><p>  對設(shè)計任務(wù)內(nèi)容的概述</p><p>  用程序?qū)崿F(xiàn)插入法排序、起泡法改進算法排序;利用插入排序和冒泡法的改進算法,將用戶隨機輸入的一列數(shù)按遞增的順序排好。輸入的數(shù)據(jù)形式為任何一個正整數(shù),大小不限。輸出的形式:數(shù)字大小逐個遞增的數(shù)列。</p><p><

32、b>  需求分析或功能描述</b></p><p>  插入排序的基本思想是:每次將一個待排序的記錄,按其關(guān)鍵字大小插入到前面已經(jīng)排好序的子表中的適當(dāng)位置,直到每次記錄插入完成為止。本程序使用直接插入排序。</p><p>  交換排序的基本思想是:兩兩比較待排序記錄的關(guān)鍵字,發(fā)現(xiàn)兩個記錄的次序相反時即進行交換,直到?jīng)]有反序的記錄為止。本程序使用改進的冒泡排序算法。<

33、;/p><p>  概要設(shè)計或程序流程圖</p><p>  直接插入排序:假設(shè)待排序的記錄存放在數(shù)組R[0..n-1]中,排序過程的某一中間時刻,R被劃分成兩個子區(qū)間[0..i-1]和[i..n-1](剛開始時i=1,有序區(qū)序號只有R[0]一個記錄),其中:前一個子區(qū)間是已排好序的有序區(qū),后一個子區(qū)間則是當(dāng)前未排序的部分,不妨稱其為無序區(qū)。直接插入排序的基本操作是將當(dāng)前無序區(qū)的第一個記錄R[

34、i]插入到有序區(qū)[0..i-1]中適當(dāng)?shù)奈恢蒙希筟0..i]變?yōu)樾碌挠行騾^(qū)。</p><p>  有序區(qū) 無序區(qū)</p><p><b>  一趟排序</b></p><p>  有序區(qū) 無序區(qū)</p><p>  直接插入排序的一趟排序過程</

35、p><p>  冒泡排序:整個算法是從最下面的記錄開始,對每兩個相臨的關(guān)鍵字進行比較,且使關(guān)鍵字較小的記錄換至關(guān)鍵字較大的記錄之上,使得經(jīng)過一趟冒泡排序之后,關(guān)鍵字最小的記錄到達最上端,接著,再在剩下的記錄中找關(guān)鍵字次小的記錄,并把它換在第二個位置上。依次類推,一直到所有記錄都有序為止。而在有些情況下,在第i(i<n-1)趟時已排好序了,但仍執(zhí)行后面幾趟的比較。實際上,一旦酸法中某一趟比較時不出現(xiàn)任何記錄交換,

36、說明已經(jīng)排好序了,就可以結(jié)束本算法。為此,改進了冒泡排序算法。 </p><p>  有 有</p><p>  序 序</p><p>  區(qū) 一趟排序

37、 區(qū)</p><p><b>  無</b></p><p>  序 無</p><p>  區(qū) 序</p><p><b>  區(qū)</

38、b></p><p>  程序模塊及其接口描述</p><p>  typedef int KeyType; //定義關(guān)鍵字類型為int</p><p>  typedef char InfoType[10];</p><p>  typedef struct //記錄類型</p>

39、<p><b>  {</b></p><p>  KeyType key; //關(guān)鍵字類型</p><p>  InfoType data; //其他數(shù)據(jù)項,類型為InfoType</p><p>  }RecType ;//排序的記錄類型定義</p>

40、;<p>  void InsertSort(RecType R[],int n)//直接插入排序</p><p>  void BubbleSort(RecType R[],int n)//改進冒泡排序</p><p>  程序的輸入與輸出描述:</p><p><b>  直接插入排序:</b></p><

41、p><b>  輸入:</b></p><p><b>  輸出:</b></p><p><b>  冒泡排序:</b></p><p><b>  輸入:</b></p><p><b>  輸出:</b></p>

42、;<p><b>  調(diào)試分析或程序測試</b></p><p><b>  直接插入排序:</b></p><p><b>  冒泡排序:</b></p><p>  尚未解決的問題或改進方向</p><p>  在算法的定義中,一開始就定義數(shù)組長度為10,如果

43、用戶操作中輸入了大于10個數(shù)時將只對前10個數(shù)進行操作,而后面的數(shù)不會參加運算。</p><p><b>  對軟件的使用說明</b></p><p>  在CFree4.0下打開軟件,進行操作。</p><p><b>  結(jié)論及體會</b></p><p>  在這次的數(shù)據(jù)結(jié)構(gòu)程序設(shè)計中,從十三

44、個題目中選了五個自己比較感興趣的題目進行編程,因為許多算法可以在書上找到類似的類型,加上自己的想法,做的可以說比較順利。和平時上機所做的不同,這次需要一個程序的主界面,用來調(diào)用所設(shè)計的五個項目,而且分別對五個項目的程序設(shè)計從構(gòu)思,到算法,再到輸入輸出和調(diào)試,進行了比較充分的說明,使用起來也比較方便。</p><p><b>  附錄</b></p><p><b

45、>  附錄1:參考文獻</b></p><p>  [1]李春葆.數(shù)據(jù)結(jié)構(gòu)學(xué)習(xí)指導(dǎo).清華大學(xué)出版社,2010</p><p>  [2]張曉莉等.數(shù)據(jù)結(jié)構(gòu)與算法.機械工業(yè)出版社,2002</p><p>  [3]李春葆.數(shù)據(jù)結(jié)構(gòu)教程上機實驗指導(dǎo).清華大學(xué)出版社,2010.</p><p>  附錄2:部分源代碼清單<

46、/p><p>  ********************************************************文章編輯;</p><p>  #define MAX 3000 </p><p>  typedef struct

47、 </p><p><b>  { </b></p><p>  char data[MAX]; </p><p>  int length; </p><p>  }SqString; </p><p>  void StrAss

48、ign(SqString &str,char cstr[])//建立串 </p><p><b>  {</b></p><p><b>  int i;</b></p><p>  for(i=0;cstr[i]!='\0';i++)</p><p>  str.data[

49、i]=cstr[i];</p><p>  str.length=i;</p><p><b>  }</b></p><p>  void DispStr(SqString p)</p><p><b>  {</b></p><p><b>  int i;&l

50、t;/b></p><p>  if(p.length>0)</p><p>  { printf("當(dāng)前的文章為:");</p><p>  for(i=0;i<p.length;i++)</p><p><b>  {</b></p><p>  pri

51、ntf("%c",p.data[i]);</p><p>  if((i+1)%80==0)</p><p>  printf("\n");</p><p><b>  }</b></p><p><b>  }</b></p><p>

52、;<b>  }</b></p><p>  int cout(SqString p)//各種字符數(shù)量統(tǒng)計 </p><p><b>  {</b></p><p>  int i=0;int a=0 ,b=0,c=0,d=0; </p>

53、;<p>  for(i=0;i<p.length;i++)</p><p><b>  {</b></p><p>  if(p.data[i]>='a'&&p.data[i]<='z')</p><p><b>  a++;</b><

54、/p><p>  if(p.data[i]>='A'&&p.data[i]<='Z')</p><p><b>  b++;</b></p><p>  if(p.data[i]>='0'&&p.data[i]<='9')<

55、/p><p><b>  c++;</b></p><p>  if(p.data[i]==32)</p><p><b>  d++;</b></p><p><b>  }</b></p><p>  printf("英文小寫字母有:%d個\n

56、",a) ;</p><p>  printf("英文大寫字母有:%d個\n",b) ;</p><p>  printf("數(shù)字有:%d個\n",c);</p><p>  printf("空格有:%d個\n",d);</p><p>  return p.length;

57、</p><p><b>  }</b></p><p>  int FindFind(SqString p,SqString q)//查找 </p><p><b>  {</b></p><p>  int i=0;int j=0;int n=0;</p><p>  w

58、hile(i<=p.length)</p><p><b>  {</b></p><p>  if((p.data[i]==q.data[j])&&(q.data[j]!='\0'))</p><p>  {i++;j++;}</p><p><b>  else<

59、/b></p><p><b>  i++;</b></p><p>  if(j>=q.length)</p><p>  {n++;j=0;}</p><p><b>  }</b></p><p>  printf("經(jīng)查找個字符共有 %d 個\n

60、",n);</p><p><b>  }</b></p><p>  SqString Dele(SqString p,SqString a)//刪除 </p><p><b>  {</b></p><p>  int i=0;int j=0;int n=0;int pos=0; &l

61、t;/p><p>  while(i<=p.length)</p><p><b>  {</b></p><p>  if((p.data[i]==a.data[j])&&(a.data[j]!='\0'))</p><p>  {i++;j++;}</p><p&

62、gt;<b>  else </b></p><p><b>  i++;</b></p><p>  if(j>=a.length)</p><p>  { pos=i-j+1;</p><p><b>  int k;</b></p><p&g

63、t;  SqString b;b.length=0;</p><p>  if(pos<=0||pos>=p.length||pos+a.length>p.length+1)</p><p><b>  return b;</b></p><p>  for(k=0;k<pos-1;k++)</p><

64、;p>  b.data[k]=p.data[k];</p><p>  for(k=pos+j-1;k<p.length;k++)</p><p>  b.data[k-j]=p.data[k];</p><p>  b.length=p.length-a.length;</p><p><b>  return b;&

65、lt;/b></p><p><b>  pos=0;</b></p><p><b>  j=0;</b></p><p><b>  }</b></p><p><b>  } </b></p><p><b>

66、  }</b></p><p>  ********************************************************猴子選大王;</p><p>  #define MaxSize 50</p><p>  int houzi(int n,int m)</p><p><b>  {<

67、;/b></p><p>  int p[MaxSize];</p><p>  int i,j,t;</p><p>  for(i=0;i<n;i++)</p><p><b>  p[i]=i+1;</b></p><p><b>  t=0;</b><

68、;/p><p>  printf("\n出列順序:");</p><p>  for(i=n;i>=1;i--)</p><p><b>  {</b></p><p>  t=(t+m-1)%i;</p><p>  printf("%d",p[t]);

69、</p><p>  for(j=t+1;j<=i-1;j++)</p><p>  p[j-1]=p[j];</p><p>  } printf("\n");</p><p>  printf("\n故編號 %d 的猴子是大王!\n",p[t]);</p><p> 

70、 printf("\n");</p><p><b>  }</b></p><p>  *******************************************************創(chuàng)建二叉樹:</p><p>  #define MaxSize 100</p><p>  type

71、def char ElemType;</p><p>  typedef struct node</p><p><b>  {</b></p><p>  ElemType data;//數(shù)據(jù)元素 </p><p>  struct node *lchild;//指向左孩子 </p><p> 

72、 struct node *rchild;//指向右孩子 </p><p><b>  }BTNode;</b></p><p>  void CreateBTNode(BTNode *&b,char *str)//由str串創(chuàng)建二叉鏈 </p><p><b>  {</b></p><p&

73、gt;  BTNode *St[MaxSize],*p=NULL;</p><p>  int top=-1,k,j=0;</p><p><b>  char ch;</b></p><p>  b=NULL;//建立的二叉樹初始時為空 </p><p>  ch=str[j];</p><p>

74、;  while(ch!='\0')//str未掃描完時循環(huán) </p><p><b>  {</b></p><p>  switch(ch)</p><p><b>  {</b></p><p>  case '(':top++;St[top]=p;k=1;br

75、eak;//為左結(jié)點 </p><p>  case ')':top--;break;</p><p>  case ',':k=2;break;//為右結(jié)點 </p><p>  default:p=(BTNode *)malloc(sizeof(BTNode));</p><p>  p->data=

76、ch;</p><p>  p->lchild=p->rchild=NULL;</p><p>  if(b==NULL)//p指向二叉樹的根結(jié)點 </p><p><b>  b=p;</b></p><p>  else//已建立二叉樹根結(jié)點 </p><p><b> 

77、 {</b></p><p><b>  switch(k)</b></p><p><b>  {</b></p><p>  case 1:St[top]->lchild=p;break;</p><p>  case 2:St[top]->rchild=p;break;

78、</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  j++;</b></p><p>  ch=str[j];</p>

79、<p><b>  }</b></p><p><b>  }</b></p><p>  void DispBTNode(BTNode *b)//以括號表示法輸出二叉樹 </p><p><b>  {</b></p><p>  if(b!=NULL)</p

80、><p><b>  {</b></p><p>  printf("%c",b->data);</p><p>  if(b->lchild!=NULL||b->rchild!=NULL)</p><p><b>  {</b></p><p&

81、gt;  printf("(");</p><p>  DispBTNode(b->lchild);</p><p>  if(b->rchild!=NULL) printf(",");</p><p>  DispBTNode(b->rchild);</p><p>  printf

82、(")");</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  void TravLevel(BTNode *b)//層次遍歷</p><p>

83、<b>  {</b></p><p>  BTNode *Qu[MaxSize];</p><p>  int front,rear;</p><p>  front=rear=0;</p><p>  if(b!=NULL)</p><p>  printf("%c",b-

84、>data); </p><p><b>  rear++;</b></p><p>  Qu[rear]=b;</p><p>  while(rear!=front)</p><p><b>  {</b></p><p>  front=(front+1)%Max

85、Size;</p><p>  b=Qu[front];</p><p>  if(b->lchild!=NULL)</p><p><b>  {</b></p><p>  printf("%c",b->lchild->data);</p><p>  r

86、ear=(rear+1)%MaxSize;</p><p>  Qu[rear]=b->lchild;</p><p><b>  }</b></p><p>  if(b->rchild!=NULL)</p><p><b>  {</b></p><p>  

87、printf("%c",b->rchild->data);</p><p>  rear=(rear+1)%MaxSize;</p><p>  Qu[rear]=b->rchild;</p><p><b>  }</b></p><p><b>  }</b>

88、;</p><p>  printf("\n");</p><p><b>  }</b></p><p>  void PreOrder(BTNode *b)//先序遍歷的遞歸算法 </p><p><b>  {</b></p><p>  if(b!

89、=NULL)</p><p><b>  {</b></p><p>  printf("%c",b->data);//訪問根結(jié)點 </p><p>  PreOrder(b->lchild);//先序遍歷左子樹 </p><p>  PreOrder(b->rchild);//先序

90、遍歷右子樹 </p><p><b>  }</b></p><p><b>  }</b></p><p>  void menu8()</p><p><b>  {</b></p><p>  BTNode *b;</p><p

91、>  char s[MaxSize];</p><p>  printf("請輸入二叉樹:");</p><p><b>  gets(s);</b></p><p>  CreateBTNode(b,s);</p><p>  printf("輸出此二叉樹:");</

92、p><p>  DispBTNode(b);</p><p>  printf("\n");</p><p>  printf("層序遍歷序列:");</p><p>  TravLevel(b);</p><p>  printf("先序遍歷遞歸序列:");&l

93、t;/p><p>  PreOrder(b);</p><p>  printf("\n");</p><p><b>  }</b></p><p>  #include <stdio.h></p><p>  #define MAXE 20</p>&

94、lt;p>  typedef int KeyType;</p><p>  typedef char InfoType[10];</p><p>  typedef struct</p><p><b>  {</b></p><p>  KeyType key;</p><p>  Inf

95、oType data;</p><p><b>  }RecType;</b></p><p>  ****************************************************************拓撲排序:</p><p>  #define STACKSIZE 100 //棧空間大小 &

96、lt;/p><p>  #define STACKINCREMENT 20 //進棧棧增量 </p><p>  #define MAX 20 //鄰接表數(shù)組的最大值 </p><p>  typedef struct</p><p><b>  {</b></p&

97、gt;<p>  int *base; //棧底 </p><p>  int *top; //棧頂 </p><p>  int stacksize; //??臻g </p><p><b>  }Stack;</b><

98、;/p><p>  int InitStack(Stack &s) //創(chuàng)建一個空棧</p><p><b>  {</b></p><p>  s.base=(int*)malloc(STACKSIZE*sizeof(int));</p><p>  if(!s.base)</p>

99、<p>  return -1;</p><p>  s.top=s.base;</p><p>  s.stacksize=STACKSIZE;</p><p><b>  return 1;</b></p><p><b>  }</b></p><p>  

100、int Push(Stack &s,int e) //進棧 </p><p><b>  {</b></p><p>  if((s.top-s.base)>s.stacksize)</p><p><b>  {</b></p><p>  s.base=(int*

101、)realloc(s.base,(STACKSIZE+STACKINCREMENT)*sizeof(int));</p><p>  if(!s.base)</p><p><b>  return-1;</b></p><p>  s.top=s.base+s.stacksize;</p><p>  s.stacks

102、ize+=STACKINCREMENT;</p><p><b>  }</b></p><p>  *s.top++=e;</p><p><b>  return 1;</b></p><p><b>  }</b></p><p>  bool E

103、mpty(Stack s) //查看棧是否為空 </p><p><b>  {</b></p><p>  if(s.base==s.top)</p><p>  return true;</p><p><b>  else</b></p><p&

104、gt;  return false;</p><p><b>  }</b></p><p>  int Pop(Stack &s) //出棧 </p><p><b>  {</b></p><p><b>  int e;</b>&l

105、t;/p><p>  e=*--s.top;</p><p><b>  return e;</b></p><p><b>  }</b></p><p>  typedef struct ArcNode //頭節(jié)點</p><p><b>  {

106、</b></p><p>  int adjvex; //該邊所指向的頂點的位置</p><p>  struct ArcNode *nextarc; //指向下一條邊</p><p><b>  }ArcNode;</b></p><p>  typedef str

107、uct VNode //表節(jié)點</p><p><b>  {</b></p><p>  int data; //頂點信息</p><p>  int indegree; //節(jié)點的入度</p><p>  ArcNode *f

108、irstarc; //指向第一條依附該節(jié)點的邊的指針</p><p>  }VNode,AdjList[MAX];</p><p>  typedef struct </p><p><b>  {</b></p><p>  AdjList vertices; //表節(jié)點<

109、;/p><p>  int vexnum; //節(jié)點的個數(shù)</p><p>  int arcnum; //邊的條數(shù)</p><p><b>  }Graph;</b></p><p>  int LocateVex(Graph G,int v) /

110、/返回節(jié)點v在圖中的位置</p><p><b>  {</b></p><p><b>  int i;</b></p><p>  for(i=0;i<G.vexnum;++i)</p><p><b>  {</b></p><p>  if

111、(G.vertices[i].data==v)</p><p><b>  break;</b></p><p><b>  else</b></p><p><b>  continue;</b></p><p><b>  }</b></p>

112、;<p>  if(i<G.vexnum)</p><p><b>  return i;</b></p><p><b>  else </b></p><p>  return -1;</p><p><b>  }</b></p><

113、;p>  void CreateGraph(Graph &G) //建圖 </p><p><b>  {</b></p><p><b>  int m,n;</b></p><p>  printf("①現(xiàn)在請輸入DAG的結(jié)點數(shù): ");</p><p

114、>  scanf("%d",&m);</p><p>  while(m<0)</p><p><b>  {</b></p><p>  printf("\t\t\t\tError!\n\t\t\t\tDAG結(jié)點數(shù)不能小于1.\n");</p><p>  p

115、rintf("請重新輸入DAG的頂點數(shù): "); //DAG是有向無環(huán)圖 </p><p>  scanf("%d",&m);</p><p><b>  }</b></p><p>  printf("②現(xiàn)在請輸入DAG的邊數(shù): ");</p><p&

116、gt;  scanf("%d",&n);</p><p>  while(n<0)</p><p><b>  {</b></p><p>  printf("\t\t\t\tError!\n\t\t\t\tDAG的邊數(shù)不能小于0.\n");</p><p>  pr

117、intf("請重新輸入DAG的邊數(shù): ");</p><p>  scanf("%d",&n);</p><p><b>  }</b></p><p>  G.vexnum=m; //頂點數(shù)目</p><p>  G.arcnum=

118、n; //邊的數(shù)目</p><p>  int i,j,k;</p><p>  for(i=0;i<G.vexnum;++i) //初始化圖的信息</p><p><b>  {</b></p><p>  G.vertices[i].data=i+1;

119、 //頂點信息</p><p>  G.vertices[i].firstarc=0;</p><p>  G.vertices[i].indegree=0; //開始時入度都為0</p><p><b>  }</b></p><p><b>  //頂點信息</b></p&

120、gt;<p>  printf("③現(xiàn)在輸出頂點信息:\n");</p><p>  for(i=0;i<G.vexnum;++i)</p><p>  printf("v%d\n",G.vertices[i].data);</p><p>  int v1,v2,flag=0;</p>&l

121、t;p>  for(k=0;k<G.arcnum;++k)</p><p><b>  {</b></p><p>  printf("④請輸入第%d邊的起點和終點(樣例:1 2),注意其中分隔符為一個空格: ",k+1);</p><p>  scanf("%d%d",&v1,&am

122、p;v2);</p><p>  i=LocateVex(G,v1); //頂點v1在圖中的位置</p><p>  j=LocateVex(G,v2); //頂點v2在圖中的位置</p><p>  if(i >=0 && j>=0)</p><p><

123、;b>  {</b></p><p><b>  ++flag;</b></p><p>  (G.vertices[j].indegree)++;</p><p>  ArcNode *p=(ArcNode*)malloc(sizeof(ArcNode));</p><p>  p->adjve

124、x=j;</p><p>  p->nextarc=0;</p><p>  ArcNode *p1;</p><p>  if(! G.vertices[i].firstarc)</p><p>  G.vertices[i].firstarc=p;</p><p><b>  else</b&

125、gt;</p><p><b>  {</b></p><p>  for(p1=G.vertices[i].firstarc;p1->nextarc;p1=p1->nextarc); //求該頂點的最后一個鄰接頂點</p><p>  p1->nextarc=p; //將p插入到最后一個鄰接頂點

126、的后面</p><p><b>  }</b></p><p><b>  }</b></p><p>  else //沒有該弧,刪除掉</p><p><b>  {</b></p><p>  printf("********

127、***************************************"); </p><p>  printf("沒有該邊!\n");</p><p><b>  k=flag;</b></p><p>  printf("************************************

128、***********"); </p><p><b>  } </b></p><p><b>  }</b></p><p><b>  }</b></p><p>  void TopologicalSort(Graph G) //拓撲排序函數(shù)</p&g

129、t;<p><b>  {</b></p><p>  int i,j,k;</p><p>  int count=0; //用來統(tǒng)計頂點的個數(shù)</p><p>  Stack s; //定義一個棧,用來保存入度為0的頂點</p><p>  InitStack(s); //初始化棧</p&g

130、t;<p>  for(i=0;i<G.vexnum;++i)</p><p>  if(G.vertices[i].indegree==0) //若第i個頂點的入度為0 ,i表示頂點在圖中的位置</p><p>  Push(s,i); //將第i個頂點入棧</p><p>  while(!Empty(

131、s))</p><p><b>  {</b></p><p>  j=Pop(s); // 將為入度0的頂點位置出棧,并保存到j(luò)中</p><p>  count++; //統(tǒng)計頂點的個數(shù)</p><p>  printf("v%d ",G.vertices[j].data

132、); //輸出入度為0的頂點</p><p>  ArcNode *p;</p><p>  for(p=G.vertices[j].firstarc; p ;p=p->nextarc) //找與第j個頂點的鄰接頂點,并將其入度減1</p><p><b>  {</b></p><p>  k=p->a

133、djvex;</p><p>  --(G.vertices[k].indegree);</p><p>  if(G.vertices[k].indegree==0) //如果入度為0,就入棧</p><p>  Push(s,k);</p><p><b>  }</b></p><p>

134、;<b>  }</b></p><p>  if(count<G.vexnum) //count小于頂點的個數(shù)時候,說明有環(huán),不符合拓撲排序的要求</p><p><b>  {</b></p><p>  printf("***************************************

135、*****************************************"); </p><p>  printf("\t\t\t\tError!\n\t\t\t\t圖中有環(huán)!該圖不是DAG!\n");</p><p>  exit(0); //退出</p><p><b>  }<

136、/b></p><p><b>  }</b></p><p><b>  //主函數(shù)的實現(xiàn)</b></p><p>  /*void TuoPu()</p><p><b>  {</b></p><p>  printf("\t\t\

137、t\t拓撲排序演示\n");</p><p>  printf("\t\t\t\t現(xiàn)在開始\n");</p><p><b>  Graph g;</b></p><p>  CreateGraph(g);</p><p>  printf("\n\t\t\t\t拓撲排序結(jié)果為:

138、\n");</p><p>  printf("************************************************"); </p><p>  TopologicalSort(g);</p><p>  printf("\n*************************************

139、***********"); </p><p>  printf("\n\t\t\t\t演示完畢\n");</p><p><b>  }*/</b></p><p>  *****************************************************各種排序</p><

140、;p>  void InsertSort(RecType R[],int n)//直接插入排序 </p><p><b>  {</b></p><p>  int i,j,k;</p><p>  RecType temp;</p><p>  for(i=1;i<n;i++)</p><

141、;p><b>  {</b></p><p>  temp=R[i];</p><p>  j=i-1; //從左向右在有序區(qū)R[0..i-1]中找R[i]的插入位置</p><p>  while(j>=0&&temp.key<R[j].key)</p><p><

溫馨提示

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

評論

0/150

提交評論