數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告_第1頁
已閱讀1頁,還剩21頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

1、<p><b>  數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)</b></p><p>  計(jì)算機(jī)科學(xué)與通信工程學(xué)院</p><p><b>  姓名: </b></p><p><b>  學(xué)號(hào):</b></p><p><b>  指導(dǎo)老師: </b></p&g

2、t;<p>  時(shí)間:2013-1-15</p><p><b>  目錄</b></p><p>  課程設(shè)計(jì)目的……………………2</p><p>  課程設(shè)計(jì)的要求…………………2</p><p>  課程設(shè)計(jì)具體內(nèi)容………………2</p><p>  二叉排序樹………………2

3、</p><p><b> ?。?)需求分析</b></p><p><b> ?。?)設(shè)計(jì)說明</b></p><p><b> ?。?)代碼</b></p><p><b> ?。?)運(yùn)行結(jié)果</b></p><p> ?。ǘ?/p>

4、排序………………………11</p><p><b> ?。?)需求分析</b></p><p><b>  (2)設(shè)計(jì)說明</b></p><p><b> ?。?)代碼</b></p><p><b> ?。?)運(yùn)行結(jié)果</b></p>&

5、lt;p>  心得體會(huì)………………………22</p><p>  參考文獻(xiàn)………………………22</p><p><b>  一、課程設(shè)計(jì)目的</b></p><p>  課程設(shè)計(jì)是一種全面的綜合訓(xùn)練,是課堂教學(xué)的延續(xù)。</p><p>  對(duì)學(xué)生數(shù)據(jù)結(jié)構(gòu)知識(shí)的全面綜合訓(xùn)練,把書上學(xué)到的知識(shí)用于解決實(shí)際問題、培養(yǎng)今

6、后軟件開發(fā)工作所需的動(dòng)手實(shí)踐能力,包括問題分析、總體結(jié)構(gòu)設(shè)計(jì)、用戶界面的設(shè)計(jì)、程序設(shè)計(jì)的基本技能和技巧,以及一整套軟件工作規(guī)范的訓(xùn)練和團(tuán)體協(xié)作精神的培養(yǎng)。</p><p><b>  二、課程設(shè)計(jì)的要求</b></p><p><b>  程序運(yùn)行正確。</b></p><p>  報(bào)告要求:課程設(shè)計(jì)報(bào)告以書面形式和電子版

7、兩種形式提交。</p><p><b>  遵守誠實(shí)代碼原則。</b></p><p>  三、課程設(shè)計(jì)具體內(nèi)容</p><p><b>  (一)二叉排序樹</b></p><p><b>  (1)需求分析:</b></p><p>  1.運(yùn)行環(huán)境

8、:Microsoft Visual C++6.0</p><p>  2.程序所實(shí)現(xiàn)的功能:給出一組關(guān)鍵值,建立相應(yīng)的二叉排序 樹,完成:</p><p>  ①結(jié)點(diǎn)的刪除操作。要求可以實(shí)現(xiàn)刪除根節(jié)點(diǎn),葉子節(jié)點(diǎn)以及其他任意節(jié)點(diǎn)的功能;</p><p>  ②插入一個(gè)新結(jié)點(diǎn)的操作</p><p> ?、蹖?duì)給定的值在二叉排序樹

9、進(jìn)行操作</p><p>  ④隨時(shí)顯示操作的結(jié)果</p><p><b>  (2)設(shè)計(jì)說明:</b></p><p>  1.算法設(shè)計(jì)思想:運(yùn)用結(jié)構(gòu)體建立二叉樹,并實(shí)現(xiàn)其各個(gè)功能。二叉排序樹的輸出用中序遍歷,則按從小到大的順序依次輸出各元素。</p><p><b>  2.流程圖:</b>&l

10、t;/p><p><b>  (3)代碼:</b></p><p>  #include<iostream></p><p>  using namespace std;</p><p>  struct BSTree</p><p><b>  {</b></

11、p><p><b>  int data;</b></p><p>  BSTree *left;</p><p>  BSTree *right;</p><p><b>  };</b></p><p>  bool flag = false;</p><

12、p>  int a[100];</p><p><b>  //查找操作</b></p><p>  BSTree *search(BSTree *r,int x)</p><p><b>  {</b></p><p>  if(r==NULL)</p><p>  

13、return NULL;</p><p><b>  else</b></p><p><b>  {</b></p><p>  if(r->data==x)</p><p><b>  return r;</b></p><p>  else

14、if(r->data>x)</p><p>  return search(r->left,x);</p><p><b>  else</b></p><p>  return search(r->right,x);</p><p><b>  }</b></p>

15、;<p>  }BSTree* insert(BSTree *r,BSTree *s) //插入操作</p><p><b>  {</b></p><p>  BSTree *p = search(r,s->data); //首先查找樹中是否已存在此節(jié)點(diǎn)</p><p>  if(p==NULL)</p>&

16、lt;p><b>  {</b></p><p>  if(r==NULL)</p><p><b>  {</b></p><p><b>  r=s;</b></p><p><b>  }</b></p><p>  e

17、lse if(s->data<r->data)</p><p>  r->left = insert(r->left,s);</p><p>  else if(s->data>r->data)</p><p>  r->right = insert(r->right,s);</p><

18、p><b>  }</b></p><p><b>  else</b></p><p>  flag = true;</p><p><b>  return r;</b></p><p><b>  }</b></p><p&

19、gt;  BSTree * createBSTree(BSTree *r,int *a,int n)</p><p><b>  {</b></p><p><b>  int i;</b></p><p>  BSTree * t;</p><p><b>  t = r;</b&

20、gt;</p><p>  for(i=0;i<n;i++)</p><p><b>  {</b></p><p>  BSTree *s = (BSTree*)malloc(sizeof(BSTree));</p><p>  s->data=a[i];</p><p>  s-&

21、gt;left=NULL;</p><p>  s->right=NULL;</p><p>  t = insert(t,s);</p><p><b>  }</b></p><p><b>  return t;</b></p><p><b>  }&

22、lt;/b></p><p>  BSTree *getFather(BSTree *r, BSTree *s)</p><p><b>  {</b></p><p>  BSTree *sf;</p><p>  if(r==NULL||r==s)</p><p><b> 

23、 sf=NULL;</b></p><p><b>  else</b></p><p><b>  {</b></p><p>  if(s==r->left||s==r->right)</p><p><b>  sf= r;</b></p&g

24、t;<p>  else if(s->data > r->data)</p><p>  sf=getFather(r->right,s);</p><p><b>  else</b></p><p>  sf=getFather(r->left,s);</p><p>&l

25、t;b>  }</b></p><p>  return sf;</p><p><b>  }</b></p><p>  BSTree * deleteNode(BSTree *r,BSTree *s) //刪除操作</p><p><b>  {</b></

26、p><p>  BSTree *temp,*father,*sf;</p><p>  sf=getFather(r,s);</p><p>  if(s->left==NULL&&s->right==NULL&&sf!=NULL) //被刪除結(jié)點(diǎn)是葉子結(jié)點(diǎn), 不是根結(jié)點(diǎn)</p><p>  if

27、(sf->left==s)</p><p>  sf->left=NULL;</p><p><b>  else</b></p><p>  sf->right=NULL;</p><p>  else if(s->left==NULL&&s->right==NULL&am

28、p;&sf!=NULL) //被刪除結(jié)點(diǎn)是葉子結(jié)點(diǎn),又是根結(jié)點(diǎn)</p><p><b>  r=NULL;</b></p><p>  else if(s->left==NULL&&s->right!=NULL&&sf!=NULL)</p><p>  if(sf->left==s)&

29、lt;/p><p>  sf->left=s->right;</p><p><b>  else</b></p><p>  sf->right=s->right; </p><p>  else if(s->left==NULL&&s->right!=NULL&

30、&sf==NULL) //被刪除結(jié)點(diǎn)有右孩子,無左孩子.刪結(jié)點(diǎn)是根結(jié)點(diǎn)</p><p>  r=s->right;</p><p>  else if(s->left!=NULL&&s->right==NULL&&sf!=NULL) //被刪結(jié)點(diǎn)有左孩子,無右孩子.刪結(jié)點(diǎn)不是根結(jié)點(diǎn)</p><p>  if(

31、sf->left==s)</p><p>  sf->left=s->left;</p><p><b>  else</b></p><p>  sf->right=s->left;</p><p>  else if(s->left!=NULL&&s->rig

32、ht==NULL&&sf==NULL) //被刪結(jié)點(diǎn)有左孩子,無右孩子.刪結(jié)點(diǎn)是根結(jié)點(diǎn)</p><p>  r=s->left;</p><p>  else if(s->left!=NULL&&s->right!=NULL)</p><p><b>  {</b></p>&l

33、t;p>  temp = s->left;</p><p>  father = s;</p><p>  while(temp->right!=NULL) //找出左子樹最大的節(jié)點(diǎn)</p><p><b>  {</b></p><p>  father=temp;</p><p&

34、gt;  temp=temp->right;</p><p><b>  }</b></p><p>  s->data = temp->data;</p><p>  if(father!=s)</p><p>  father->right = temp->left;</p>

35、<p><b>  else</b></p><p>  father->left=temp->left;</p><p><b>  }</b></p><p>  if(r==NULL)</p><p>  cout<<"刪除之后,二叉排序樹為空!

36、"<<endl;</p><p><b>  else</b></p><p>  cout<<"刪除成功!"<<endl;</p><p>  return r;</p><p><b>  }</b></p>&

37、lt;p>  BSTree *inorder(BSTree *r)</p><p><b>  {</b></p><p>  if (r!=NULL)</p><p><b>  {</b></p><p>  inorder(r->left);</p><p&g

38、t;  cout<<r->data<<" ";</p><p>  inorder(r->right);</p><p><b>  }</b></p><p><b>  return 0;</b></p><p><b>  

39、}</b></p><p>  int main(int argc,char * argv[])</p><p><b>  {</b></p><p>  int cases;</p><p>  cout<<"請(qǐng)輸入二叉樹個(gè)數(shù):";</p><p>

40、  cin>>cases;</p><p>  cout<<endl;</p><p>  while(cases--)</p><p><b>  {</b></p><p><b>  int n;</b></p><p>  flag = fal

41、se;</p><p>  BSTree *root=NULL;</p><p>  cout<<"請(qǐng)輸入元素個(gè)數(shù):";</p><p><b>  cin>>n;</b></p><p>  cout<<endl;</p><p><

42、b>  int i;</b></p><p>  cout<<"請(qǐng)輸入這些元素:";</p><p>  for(i=0;i<n;i++)</p><p>  cin>>a[i];</p><p>  cout<<endl;</p><p>

43、;  cout<<"建立二叉排序樹!"<<endl;</p><p>  root = createBSTree(root,a,n);</p><p>  if(root!=NULL)</p><p>  {cout<<"二叉排序樹建立成功!"<<endl<<inor

44、der(root)<<endl;}</p><p><b>  else</b></p><p><b>  {</b></p><p>  cout<<"二叉排序樹建立失??!"<<endl;</p><p><b>  return

45、 0;</b></p><p><b>  }</b></p><p>  cout<<"請(qǐng)選擇您要進(jìn)行的操作(輸入括號(hào)內(nèi)的字母,大小寫均可):"<<endl;</p><p>  cout<<"1.刪除(D/d)"<<endl;</p&g

46、t;<p>  cout<<"2.插入(I/i)"<<endl;</p><p>  cout<<"3.查找(S/s)"<<endl;</p><p>  cout<<"4.退出(E/e)"<<endl;</p><p>

47、<b>  char s;</b></p><p><b>  cin>>s;</b></p><p><b>  while(1)</b></p><p><b>  {</b></p><p>  if(s=='E'||s=

48、='e')</p><p><b>  break;</b></p><p>  else if(s=='I'||s=='i')</p><p><b>  {</b></p><p>  cout<<"請(qǐng)輸入您要插入的值:&qu

49、ot;<<endl;</p><p><b>  int x;</b></p><p><b>  cin>>x;</b></p><p>  BSTree *p =(BSTree*)malloc(sizeof(BSTree));</p><p>  p->data =

50、 x;</p><p>  p->left = NULL;</p><p>  p->right = NULL;</p><p>  root = insert(root,p);</p><p>  if(flag==false)</p><p>  cout<<"插入成功!"

51、;<<endl<<inorder(root)<<endl;</p><p><b>  else</b></p><p><b>  {</b></p><p>  cout<<"此二叉樹中已存在此值!"<<endl;</p>&

52、lt;p>  flag=false;//恢復(fù)原值</p><p><b>  }</b></p><p><b>  }</b></p><p>  else if(s=='S'||s=='s')</p><p><b>  {</b>&l

53、t;/p><p>  cout<<"請(qǐng)輸入您要查找的值:"<<endl;</p><p><b>  int x;</b></p><p><b>  cin>>x;</b></p><p>  BSTree *p=search(root,x);&

54、lt;/p><p>  BSTree *pfather=getFather(root,p);</p><p>  cout<<"查找的值為:"<<p->data<<endl;</p><p>  if(pfather!=NULL)</p><p>  cout<<"

55、;其父節(jié)點(diǎn)的值為:"<<pfather->data<<endl;</p><p><b>  else</b></p><p>  cout<<"它是根節(jié)點(diǎn),沒有父節(jié)點(diǎn)!"<<endl;</p><p>  if(p->left==NULL&&am

56、p;p->right==NULL)</p><p>  cout<<"它是葉子節(jié)點(diǎn),沒有子節(jié)點(diǎn)"<<endl;</p><p><b>  else</b></p><p><b>  {</b></p><p>  if(p->left !=

57、 NULL)</p><p>  cout<<"其左兒子節(jié)點(diǎn)的值為:"<<p->left->data<<endl;</p><p><b>  else</b></p><p>  cout<<"其左兒子節(jié)點(diǎn)為空!"<<endl;&l

58、t;/p><p>  if(p->right != NULL)</p><p>  cout<<"其右兒子的值為:"<<p->right->data<<endl;</p><p><b>  else</b></p><p>  cout<<

59、;"其右兒子節(jié)點(diǎn)為空!"<<endl;</p><p><b>  }</b></p><p><b>  }</b></p><p>  else if(s=='D'||s=='d')</p><p><b>  {<

60、/b></p><p>  cout<<"請(qǐng)輸入您要?jiǎng)h除的節(jié)點(diǎn)的值:"<<endl;</p><p>  int value;</p><p>  cin>>value;</p><p>  cout<<"你確定要?jiǎng)h除嗎?(Yy/Nn)"<&l

61、t;endl;</p><p>  char order;</p><p>  cin>>order;</p><p><b>  while(1)</b></p><p><b>  {</b></p><p>  if(order=='Y'||

62、order=='y')</p><p><b>  {</b></p><p>  BSTree * node;</p><p>  node = search(root,value);</p><p>  if(node==NULL)</p><p>  cout<<

63、"該節(jié)點(diǎn)不存在!"<<endl;</p><p><b>  else</b></p><p>  {BSTree *nodeDel = deleteNode(root,node);</p><p>  cout<<inorder(root)<<endl;}</p><

64、p><b>  break;</b></p><p><b>  }</b></p><p>  else if(order=='N'||order=='n')</p><p><b>  {</b></p><p><b>  

65、break;</b></p><p><b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p>  cout<<"命令不正確,請(qǐng)重新輸入!"<<endl;

66、</p><p>  cin>>order;</p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  else</b></

67、p><p><b>  {</b></p><p>  cout<<"命令有誤,請(qǐng)重新輸入!"<<endl;</p><p><b>  }</b></p><p>  cout<<"請(qǐng)選擇您要進(jìn)行的操作:"<<en

68、dl;</p><p><b>  cin>>s;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  system("pause");</p><p><b&

69、gt;  return 0;</b></p><p><b>  }</b></p><p><b>  (4)運(yùn)行結(jié)果</b></p><p><b>  (二)排序</b></p><p><b>  (1)需求分析:</b></p&

70、gt;<p>  1.運(yùn)行環(huán)境:Microsoft Visual C++6.0</p><p>  2.程序所實(shí)現(xiàn)的功能:幾種排序算法的演示,要求給出從初始開始時(shí)的每一趟的變化情況,并對(duì)各種排序算法的排序性能作分析和比較:</p><p><b> ?、僦苯硬迦肱判?;</b></p><p><b> ?、谡郯?/p>

71、插入排序;</b></p><p><b> ?、勖芭菖判?;</b></p><p><b> ?、芎唵芜x擇排序;</b></p><p><b> ?、菘焖倥判?;</b></p><p><b> ?、薅雅判颍?lt;/b></p>

72、<p><b> ?、邭w并排序。</b></p><p><b>  (2)設(shè)計(jì)說明:</b></p><p>  1.算法設(shè)計(jì)思想:運(yùn)用順序表存放數(shù)據(jù)元素,7種排序算法均為順序表類的函數(shù)。主函數(shù)中,為了避免前一個(gè)排序結(jié)果的影響,采取選擇排序算法的方法,將各個(gè)排序算法分開。</p><p><b>  

73、2.流程圖:</b></p><p><b>  ……</b></p><p><b> ?。?)代碼:</b></p><p>  #include<iostream.h></p><p>  const int maxlen=100;</p><p&g

74、t;  int num=0;</p><p>  template<class type></p><p>  class seqlist</p><p><b>  {</b></p><p><b>  public:</b></p><p><b&g

75、t;  int len;</b></p><p>  type data[maxlen];</p><p>  seqlist(void);</p><p>  ~seqlist(void);</p><p>  int length(void);</p><p>  void merge(seqlist&

76、lt;type> &sourcetable,seqlist<type> &mergedtable,const int left,const int mid,const int right);</p><p>  void insertionsort();</p><p>  type insert(const type &item,int i);

77、</p><p>  void selectsort();</p><p>  void halfsort();</p><p>  void bubblesort();</p><p>  void swap(type &a,type &b);</p><p>  void quicksort(int

78、 low,int high);</p><p>  void mergepass(seqlist<type> &sourcetable,seqlist<type> &mergedtable,const int len);</p><p>  void mergesort(seqlist<type> &table); </p&

79、gt;<p>  void print();</p><p>  void filterdown(const int start);</p><p>  void heapsort();</p><p><b>  };</b></p><p>  template<class type><

80、;/p><p>  seqlist<type>::seqlist(void):len(0){}</p><p>  template<class type></p><p>  seqlist<type>::~seqlist(void){}</p><p>  template<class type>

81、;</p><p>  int seqlist<type>::length(void)</p><p>  {return len;}</p><p>  template<class type></p><p>  void seqlist<type>::swap(type &a,type &am

82、p;b)</p><p><b>  {</b></p><p><b>  type c;</b></p><p><b>  c=a;</b></p><p><b>  a=b;</b></p><p><b>  

83、b=c;</b></p><p><b>  }</b></p><p>  template<class type></p><p>  void seqlist<type>::print()</p><p><b>  {</b></p><

84、;p>  for(int x=0;x<len;x++)</p><p>  cout<<data[x]<<" ";</p><p>  cout<<endl;</p><p><b>  }</b></p><p>  template<clas

85、s type></p><p>  void seqlist<type>::halfsort()</p><p><b>  {</b></p><p>  type temp;</p><p>  int left,right;</p><p>  for(int i=1;i&

86、lt;len;i++)</p><p><b>  {</b></p><p><b>  left=0;</b></p><p>  right=i-1;</p><p>  temp=data[i];</p><p>  while (left<=right)<

87、;/p><p><b>  {</b></p><p>  int mid=(left+right)/2;</p><p>  if (temp<data[mid])</p><p>  right=mid-1;</p><p>  else left=mid+1;</p><

88、;p><b>  }</b></p><p>  for(int k=i-1;k>=left;k--)</p><p>  data[k+1]=data[k];</p><p>  data[left]=temp;</p><p>  cout<<"第"<<++nu

89、m<<"趟折半插入排序:";</p><p>  for(int x=0;x<len;x++)</p><p>  cout<<data[x]<<" ";</p><p>  cout<<endl;</p><p><b>  }<

90、/b></p><p><b>  num=0;</b></p><p><b>  }</b></p><p>  template<class type></p><p>  void seqlist<type>::selectsort()</p>&

91、lt;p><b>  {</b></p><p><b>  int k;</b></p><p>  for(int i=0;i<len-1;i++)</p><p><b>  {</b></p><p><b>  k=i;</b><

92、;/p><p>  for(int j=i+1;j<len;j++)</p><p>  if (data[j]<data[k])</p><p><b>  k=j;</b></p><p><b>  if(k!=i)</b></p><p>  swap(dat

93、a[i],data[k]);</p><p>  cout<<"第"<<i+1<<"趟選擇排序:";</p><p><b>  print();</b></p><p><b>  }</b></p><p><b

94、>  }</b></p><p>  template<class type></p><p>  void seqlist<type>::quicksort(int low,int high)</p><p><b>  {</b></p><p>  int i=low,j=

95、high;static int a=1;</p><p>  type temp=data[low];</p><p><b>  if(i<j)</b></p><p><b>  {</b></p><p>  while(i<j)</p><p><b

96、>  {</b></p><p>  while(i<j&&temp<data[j])</p><p><b>  j--;</b></p><p><b>  if(i<j)</b></p><p><b>  {</b>&

97、lt;/p><p>  data[i]=data[j];</p><p><b>  i++;</b></p><p><b>  }</b></p><p>  while(i<j&&temp>=data[i])</p><p><b> 

98、 i++;</b></p><p><b>  if(i<j)</b></p><p><b>  {</b></p><p>  data[j]=data[i];</p><p><b>  j--;</b></p><p><

99、b>  }</b></p><p><b>  }</b></p><p>  data[i]=temp;</p><p>  cout<<"第"<<a++<<"趟快速排序:";</p><p><b>  pr

100、int();</b></p><p>  quicksort(low,i-1);</p><p>  quicksort(i+1,high);</p><p><b>  }</b></p><p><b>  }</b></p><p>  template&l

101、t;class type></p><p>  void seqlist<type>::bubblesort()</p><p><b>  {</b></p><p><b>  int i=1;</b></p><p>  int finish=0;</p>&l

102、t;p>  while(i<len&&!finish)</p><p><b>  {</b></p><p><b>  finish=1;</b></p><p>  for(int j=0;j<len-i;j++)</p><p>  if(data[j]&g

103、t;data[j+1])</p><p>  {swap(data[j],data[j+1]);</p><p><b>  finish=0;</b></p><p><b>  }</b></p><p>  cout<<"第"<<++num<

104、<"趟冒泡排序:";</p><p>  for(int x=0;x<len;x++)</p><p>  cout<<data[x]<<" ";</p><p>  cout<<endl;</p><p><b>  i++;</b&g

105、t;</p><p><b>  }</b></p><p><b>  num=0;</b></p><p><b>  }</b></p><p>  template<class type></p><p>  void seqlist

106、<type>::merge(seqlist<type> &sourcetable,seqlist<type> &mergedtable,const int left,const int mid,const int right)</p><p><b>  {</b></p><p>  int i=left,j=m

107、id+1,k=left;</p><p>  while(i<=mid&&j<=right)</p><p>  if(sourcetable.data[i]<=sourcetable.data[j])</p><p><b>  {</b></p><p>  mergedtable.

108、data[k]=sourcetable.data[i];</p><p><b>  i++;</b></p><p><b>  k++;</b></p><p><b>  }</b></p><p><b>  else</b></p>

109、<p><b>  {</b></p><p>  mergedtable.data[k]=sourcetable.data[j];</p><p><b>  j++;</b></p><p><b>  k++;</b></p><p><b>  }

110、</b></p><p>  if(i<=mid)</p><p>  for(int p=k,q=i;q<=mid;p++,q++)</p><p>  mergedtable.data[p]=sourcetable.data[q];</p><p>  else for (int p=k,q=j;q<=rig

111、ht;p++,q++)</p><p>  mergedtable.data[p]=sourcetable.data[q];</p><p><b>  }</b></p><p>  template<class type></p><p>  void seqlist<type>::merge

112、pass(seqlist<type> &sourcetable,seqlist<type> &mergedtable,const int len)</p><p><b>  {</b></p><p><b>  int i=0;</b></p><p>  while (i+2*

113、len<=length()-1)</p><p><b>  {</b></p><p>  merge(sourcetable,mergedtable,i,i+len-1,i+2*len-1);</p><p><b>  i+=2*len;</b></p><p><b>  }

114、</b></p><p>  if (i+len<=length()-1)</p><p>  merge(sourcetable,mergedtable,i,i+len-1,length()-1);</p><p>  else for(int j=i;j<=length()-1;j++)</p><p>  mer

115、gedtable.data[j]=sourcetable.data[j];</p><p>  if(len<=length()-1)</p><p>  {if(num<length())</p><p><b>  {</b></p><p>  cout<<"第"<

116、<++num<<"趟歸并排序結(jié)果為:";</p><p>  for(int t=0;t<length();t++)</p><p>  cout<<mergedtable.data[t]<<" ";</p><p>  cout<<endl;</p>

117、<p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  template<class type></p><p>  void seqlist<type>::merg

118、esort(seqlist<type> &table)</p><p><b>  {</b></p><p>  seqlist<type> temptable;</p><p>  int len=1;</p><p>  while(len<table.length())<

119、;/p><p><b>  {</b></p><p>  mergepass(table,temptable,len);</p><p><b>  len*=2;</b></p><p>  mergepass(temptable,table,len);</p><p>&l

120、t;b>  len*=2;</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  template<class type></p><p>  void seqlist<type>::insertions

121、ort()</p><p><b>  {</b></p><p>  type temp;</p><p><b>  int j;</b></p><p>  for(int i=1;i<len;i++)</p><p><b>  {</b>

122、</p><p>  temp=data[i];</p><p><b>  j=i;</b></p><p>  while(j>0&&data[i]<data[j-1])</p><p><b>  {</b></p><p>  data[j

123、]=data[j-1];</p><p><b>  j--;</b></p><p><b>  }</b></p><p>  data[j]=temp;</p><p>  cout<<"第"<<i<<"趟直接插入排序:&quo

124、t;;</p><p><b>  print();</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  template <class type></p><p>  void seq

125、list<type>::filterdown(const int start)</p><p><b>  {</b></p><p>  int i=start,j=2*i+1;</p><p>  int tablesize=len;</p><p>  type temp=data[i];</p&

126、gt;<p>  while(j<=len-1)</p><p><b>  {</b></p><p>  if(j<len-1 && data[j]<data[j+1])</p><p><b>  j++;</b></p><p>  if(te

127、mp>=data[j])break;</p><p>  else{data[i]=data[j];i=j;j=2*j+1;</p><p><b>  }</b></p><p><b>  }</b></p><p>  data[i]=temp;</p><p>

128、<b>  }</b></p><p>  template <class type></p><p>  void seqlist<type>::heapsort()</p><p><b>  {</b></p><p>  int tablesize=len;</

129、p><p>  for(int i=(len-2)/2;i>=0;i--)</p><p>  filterdown(i); </p><p>  for(i=len-1;i>=1;i--)</p><p><b>  {</b></p><p>  swap(data[0],

130、data[i]);</p><p><b>  len--;</b></p><p>  filterdown(0);</p><p>  cout<<"第"<<++num<<"趟堆排序結(jié)果為:";</p><p>  for(int x=0;x

131、<tablesize;x++)</p><p>  cout<<data[x]<<" ";</p><p>  cout<<endl;</p><p><b>  }</b></p><p><b>  num=0;</b></p

132、><p>  len=tablesize;</p><p><b>  }</b></p><p>  #include<iostream.h></p><p>  #include"seqlist.h"</p><p>  int main()</p>

133、<p><b>  {</b></p><p><b>  int a=1;</b></p><p>  while(a!=0)</p><p><b>  {</b></p><p><b>  int m;</b></p>&

134、lt;p>  cout<<"選擇排序類型"<<endl<<"1 冒泡排序"<<endl<<"2 快速排序"<<endl<<"3 直接插入排序"<<endl;</p><p>  cout<<"4 折半插入排序&q

135、uot;<<endl<<"5 堆排序"<<endl<<"6 選擇排序"<<endl<<"7 歸并排序"<<endl<<"0 退出排序"<<endl;</p><p>  cout<<"請(qǐng)選擇:";

136、</p><p>  int choice;</p><p>  cin>>choice;</p><p>  if (choice==0)</p><p><b>  {</b></p><p>  cout<<"退出"<<endl;<

137、;/p><p><b>  return 0;</b></p><p><b>  }</b></p><p>  if(choice<0||choice>7)cout<<"請(qǐng)從0-7中選擇一個(gè)正確的數(shù)字完成排序!"<<endl;</p><p>

138、<b>  else</b></p><p><b>  {</b></p><p>  seqlist<int> be;</p><p>  cout<<"輸入待排序數(shù)的總個(gè)數(shù):";</p><p><b>  cin>>m;<

139、;/b></p><p>  cout<<"輸入待排序數(shù),用空格隔開:";</p><p>  for(int i=0;i<m;i++)</p><p>  cin>>be.data[i];</p><p><b>  be.len=m;</b></p>

140、<p>  switch(choice)</p><p><b>  {</b></p><p><b>  case 1:</b></p><p>  cout<<"冒泡排序:"<<endl;</p><p>  be.bubblesor

141、t();</p><p><b>  break;</b></p><p><b>  case 2:</b></p><p>  cout<<"快速排序:"<<endl;</p><p>  be.quicksort(0,m-1);</p>

142、<p><b>  break;</b></p><p><b>  case 3:</b></p><p>  cout<<"直接插入排序:"<<endl;</p><p>  be.insertionsort();</p><p><

143、b>  break;</b></p><p><b>  case 4:</b></p><p>  cout<<"折半插入排序:"<<endl;</p><p>  be.halfsort();</p><p><b>  break;</b

144、></p><p><b>  case 5:</b></p><p>  cout<<"堆排序:"<<endl;</p><p>  be.heapsort();</p><p><b>  break;</b></p><p&

145、gt;<b>  case 6:</b></p><p>  cout<<"選擇排序:"<<endl;</p><p>  be.selectsort();</p><p><b>  break;</b></p><p><b>  case

146、7:</b></p><p>  cout<<"歸并排序:"<<endl;</p><p>  be.mergesort(be);</p><p><b>  break;</b></p><p><b>  }</b></p>

147、<p><b>  }</b></p><p><b>  }</b></p><p>  return 0;</p><p><b>  }</b></p><p><b>  (4)運(yùn)行結(jié)果</b></p><p>

148、<b>  四、心得體會(huì)</b></p><p>  剛開始做課程設(shè)計(jì)的時(shí)候認(rèn)為這個(gè)很簡單,書上大部分的代碼都有,直接輸入到電腦里就可以運(yùn)行了。但是做起來遠(yuǎn)比想象的復(fù)雜,因?yàn)閏++學(xué)完半年,許多基礎(chǔ)知識(shí)都忘了,只好重新拾起一些零碎的知識(shí)點(diǎn)慢慢改錯(cuò)。</p><p>  我選的兩個(gè)題目分別是排序和二叉排序樹。二叉排序樹比較簡單,只要建立一個(gè)二叉樹并按順序存入即可,再根據(jù)

149、二叉樹特點(diǎn)進(jìn)行插入、刪除和查找,然后用中序遍歷將其輸出。排序則比較復(fù)雜,每一個(gè)排序算法共用一個(gè)順序表類,很容易出錯(cuò),而且剛開始的錯(cuò)相當(dāng)多,通過請(qǐng)教老師以及和同學(xué)討論才一步步的將程序調(diào)試好。</p><p>  總之,這一周的課程設(shè)計(jì),不僅讓我重拾了c++的一些知識(shí)點(diǎn),而且鞏固了這學(xué)期的數(shù)據(jù)結(jié)構(gòu)知識(shí),收獲很大。即使其間錯(cuò)誤多到差點(diǎn)放棄,但運(yùn)行結(jié)果出來的時(shí)候一切都很值得!</p><p>&l

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論