c++課程設(shè)計--基于選擇排序方法的類模板設(shè)計與實現(xiàn)_第1頁
已閱讀1頁,還剩24頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

1、<p><b>  課程設(shè)計任務(wù)書</b></p><p><b>  摘 要</b></p><p>  計算機中存儲的數(shù)據(jù),初始時沒有任何排列規(guī)律,根據(jù)實際需求,經(jīng)常要排列成有規(guī)律的數(shù)據(jù)序列也就是將數(shù)據(jù)序列按關(guān)鍵字升序或降序規(guī)律排列。</p><p>  選擇排序是排序法中很經(jīng)典的算法,選擇排序法可以分為簡單

2、選擇排序、樹形選擇排序和堆排序。</p><p>  本文采用C++語言實現(xiàn)了選擇排序功能,設(shè)計了模板類,實現(xiàn)了int型float型和char型數(shù)組的排序,設(shè)計了簡單選擇排序、樹形選擇排序和堆排序的三個函數(shù)體,采用Visual C++ 6.0的控制臺工程和MFC工程分別實現(xiàn)了各類型數(shù)組的排序,通過對兩種程序的測試結(jié)果表明:簡單選擇排序是選擇排序的基礎(chǔ),而樹形選擇排序和堆排序是簡單選擇排序的改進。</p>

3、;<p>  關(guān)鍵詞:模板類;簡單選擇排序;樹形選擇排序;堆排序;控制臺工程;MFC工程。</p><p><b>  目 錄</b></p><p><b>  1 需求分析1</b></p><p>  2 算法基本原理1</p><p><b>  3 類設(shè)計

4、3</b></p><p>  4 基于控制臺的應(yīng)用程序3</p><p>  4.1 類的接口設(shè)計4</p><p>  4.2 類的實現(xiàn)4</p><p>  4.3 主函數(shù)設(shè)計9</p><p>  4.4 基于控制臺的應(yīng)用程序測試11</p><p> 

5、 5 基于MFC的應(yīng)用程序13</p><p>  5.1 基于MFC的應(yīng)用程序設(shè)計13</p><p>  5.1.1 MFC程序界面設(shè)計13</p><p>  5.1.2 MFC程序代碼設(shè)計15</p><p>  5.2基于MFC的應(yīng)用程序測試21</p><p><b>  結(jié) 論

6、22</b></p><p><b>  參考文獻23</b></p><p><b>  1 需求分析</b></p><p> ?。?)當進行數(shù)據(jù)處理時,經(jīng)常遇到需要進行查找操作,通常希望待處理的數(shù)據(jù)按關(guān)鍵字大小有序排序,因為這樣就可以采用查找效率較高的查找算法。</p><p&g

7、t; ?。?)對有序的順序表可以采用查找效率較高的折半查找算法,而對無序的</p><p>  順序表只能采用順序查找算法。由此可見排序是計算機程序設(shè)計中一種基礎(chǔ)性操</p><p>  作,研究和掌握各種排序方法是非常重要的。</p><p> ?。?)排序算法對于計算機信息處理很重要,一個好的排序不僅可以使信息 查找的效率提高,而且直接影響著計算機的工作效率。

8、</p><p>  本實驗題目為基于選擇排序方法的類模板設(shè)計與實現(xiàn),要求建立一維數(shù)組數(shù)據(jù)結(jié)構(gòu)的模板類,使一維數(shù)組中的數(shù)據(jù)元素可以是char, int, float等多種數(shù)據(jù)類型,并對數(shù)組元素實現(xiàn)選擇類排序。因此實驗采用類模板,可以對不同的數(shù)據(jù)類型的數(shù)據(jù)進行排序,并通過函數(shù)采用不同的方法進行排序。</p><p><b>  2 算法基本原理</b></p&g

9、t;<p><b>  (1)簡單選擇排序</b></p><p>  從無序的記錄序列中選出一個關(guān)鍵字值最小的記錄存入到指定的位置。</p><p><b>  //簡單選擇排序</b></p><p>  SelectSort(Type ar[]) </p><p><b

10、>  {</b></p><p><b>  int i,j;</b></p><p><b>  Type t;</b></p><p>  for(i=1;i<len;i++)</p><p>  for(j=i+1;j<=len;j++)</p>&

11、lt;p>  if(array[i]>array[j])</p><p>  {t=array[i];array[i]=array[j];array[j]=t;}</p><p><b>  }</b></p><p><b>  (2)樹形選擇排序</b></p><p>  樹形選擇

12、排序的基本思想:樹形選擇排序又稱錦標賽排序(Tournament Sort),是一種按照錦標賽的思想進行選擇排序的方法。首先對n個記錄的關(guān)鍵字進行兩兩比較,然后在n/2個較小者之間再進行兩兩比較,如此重復(fù),直至選出最小的記錄為止。 </p><p><b> ?。?).堆排序</b></p><p>  堆排序由建初始堆和調(diào)整堆兩個過程組成。再次,所謂篩選是指對一棵左

13、右子樹均為堆的完全二叉樹,經(jīng)調(diào)整根節(jié)點后使之成為堆的過程。建堆時一定要從最后一個非葉子結(jié)點開始。</p><p>  堆排序的關(guān)鍵是調(diào)整堆,建初始堆時也是要從最后一個非葉子結(jié)點開始向根結(jié)點方向進行調(diào)整建堆。假設(shè)完全二叉樹的第i個結(jié)點的左子樹,右子樹已是堆,則對第i個結(jié)點進行調(diào)整時,需要將r[2i].key與r[2i+1].key之中的最大者與r[i].key進行比較,若r[i].key較小則與之交換。這有可能破壞

14、下一級的堆,因此,需要繼續(xù)采用上述方法調(diào)整構(gòu)造下一級的堆。如此反復(fù),直到將以第i個結(jié)點為根的子樹構(gòu)成堆為止。</p><p><b>  算法:</b></p><p>  HeapSort(Type ar[]) </p><p><b>  {</b></p><p><b>  i

15、nt i;</b></p><p>  Type t; //循環(huán)建立初始堆</p><p>  for(i=len/2;i>=1;i--) </p><p>  AdjustTree(array,i,len);</p><p>  //進行n-1次循環(huán),完成堆排序</p>&

16、lt;p>  for(i=len;i>=2;i--) </p><p>  {t=array[i];</p><p>  array[i]=array[1];</p><p>  array[1]=t;</p><p>  AdjustTree(array,1,i-1);</p><p><b&g

17、t;  }</b></p><p><b>  }</b></p><p><b>  3 類設(shè)計</b></p><p>  從上面的算法分析可以看到,本設(shè)計面臨的問題的關(guān)鍵是類模板。可以定義一個模板類sort,模板類sort功能有輸入,輸出數(shù)組,用三種方法對數(shù)組進行排序。</p><p

18、>  從問題的需要來看,在模板類中定義三個成員函數(shù)。成員函數(shù)SelectSort()對數(shù)組進行簡單選擇排序,成員函數(shù)tree_select_sort()對數(shù)組進行樹形選擇排序,成員函數(shù)HeapSort()對數(shù)組進行堆排序。成員函數(shù)AdjustTree()通過始建和調(diào)整堆輔助堆排序,而成員函數(shù)write( ) 和print( ) 輸入輸出數(shù)組。主函數(shù)中應(yīng)用if( ) 判斷語句確定數(shù)組數(shù)據(jù)類型,swich()語句選擇使用的排序方法。定

19、義了兩個對象分別是整型和字符型的。</p><p>  類用template<class Type> 限定,其中的數(shù)據(jù)類型用type代替,所有的成員函數(shù)都用template<class Type> 修飾,使之能適用于多種數(shù)據(jù)類型。</p><p>  4 基于控制臺的應(yīng)用程序</p><p>  整個程序只用一個獨立的文檔,文件中包含一個模

20、板類,主函數(shù)中定義多個對象來實現(xiàn)調(diào)用三個成員函數(shù)對數(shù)組進行簡單選擇排序,樹形選擇排序,堆排序這三種排序,在此定義了三個對象分別是整型、字符型和浮點型的。</p><p>  4.1 類的接口設(shè)計</p><p>  #include<stdio.h></p><p>  #include<string.h></p><p

21、>  #include<stdlib.h></p><p>  #include<iostream.h></p><p>  #define num 50</p><p>  #define M 50</p><p>  #define MIN_VALUE -10000</p><p> 

22、 template<class Type>class Sort</p><p><b>  {</b></p><p>  public: //外部接口</p><p>  void AdjustTree(Type ar[],int n,int k);</p><p>  void wri

23、te();</p><p>  void SelectSort(Type ar[]);</p><p>  void tree_select_sort(Type arr[],int n);</p><p>  void HeapSort(Type ar[]);</p><p>  void print(); </p><p

24、><b>  int len;</b></p><p>  Type array[num]; </p><p><b>  };</b></p><p>  在此定義了模板類,類中所有的成員函數(shù)和成員變量均定義為public的公有類型,是類的對外接口,數(shù)據(jù)類型用type代替。成員函數(shù)在類中只有函數(shù)類型,函數(shù)名,參

25、數(shù),對函數(shù)進行內(nèi)部聲明,函數(shù)體在類體外定義</p><p><b>  4.2 類的實現(xiàn)</b></p><p><b>  //簡單選擇排序</b></p><p>  template <class Type></p><p>  void Sort<Type>::Se

26、lectSort(Type ar[]) </p><p><b>  {</b></p><p><b>  int i,j;</b></p><p><b>  Type t;</b></p><p>  for(i=1;i<len;i++)</p>

27、<p>  for(j=i+1;j<=len;j++)</p><p>  if(array[i]>array[j])</p><p>  {t=array[i];array[i]=array[j];array[j]=t;}</p><p><b>  }</b></p><p>  templat

28、e <class Type></p><p>  void Sort<Type>::tree_select_sort(Type arr[],int n) //樹形選擇排序</p><p><b>  {</b></p><p>  Type tree[M]; // 樹 </p><p>  in

29、t baseSize; // 當n是2的冪次時,baseSize是n, 當n不是時,baseSize是大于n的最小的2的冪次 </p><p>  // 就是構(gòu)造成滿二叉樹的最下層的大小,即葉子數(shù) </p><p><b>  int i;</b></p><p>  Type max; // 最大值 </p><p>

30、  int maxIndex; // 最大數(shù)的下標 </p><p>  int treeSize; // 最終這棵樹會達到的大小 </p><p>  baseSize = 1;</p><p>  while (baseSize < n)</p><p><b>  {</b></p><p

31、>  baseSize *= 2;</p><p><b>  }</b></p><p>  treeSize = baseSize * 2 - 1;//滿二叉樹的所有結(jié)點個數(shù)等于葉子數(shù)的2倍減一</p><p>  for (i = 0;i < n;i++) // 從數(shù)組的后面部分開始填充, 不使用tree[0]</

32、p><p><b>  {</b></p><p>  tree[treeSize - i] = arr[i];</p><p><b>  }</b></p><p>  for (;i < baseSize;i++) // 用MIN_VALUE填充tree,直到一共有baseSize個&l

33、t;/p><p><b>  {</b></p><p>  tree[treeSize - i] = MIN_VALUE;</p><p><b>  }</b></p><p><b>  // 構(gòu)造一棵樹 </b></p><p>  for (i =

34、 treeSize;i > 1;i -= 2)</p><p><b>  {</b></p><p>  // 以arr[i]和arr[i + 1]為子結(jié)點的數(shù)的根是arr[i]和arr[i + 1]中的較大者 </p><p>  tree[i / 2] = (tree[i] > tree[i - 1] ? tree[i] :

35、tree[i - 1]);</p><p><b>  }</b></p><p>  n = n - 1; //此時的n表示當前tree[1]應(yīng)該放到arr中的位置 </p><p>  // 不斷把樹中值為最大值的結(jié)點移走,直到n的值為-1 </p><p>  while (n != -1)</p>

36、<p><b>  {</b></p><p>  max = tree[1];</p><p>  arr[n--] = max;</p><p>  maxIndex = treeSize;</p><p>  // 在葉子上找到最大值對應(yīng)的下標 </p><p>  while (

37、tree[maxIndex] != max)</p><p><b>  {</b></p><p>  maxIndex--;</p><p><b>  }</b></p><p>  tree[maxIndex] = MIN_VALUE;</p><p>  // 沿著

38、葉子上的結(jié)點到根的路徑更新 </p><p>  while (maxIndex > 1) // 當結(jié)點還有父結(jié)點時 </p><p><b>  {</b></p><p>  if (maxIndex % 2 == 0) // 如果值為最大值的結(jié)點是左子結(jié)點 </p><p><b>  {</

39、b></p><p>  // 用子結(jié)點中較大值代替父結(jié)點 </p><p>  tree[maxIndex / 2] = (tree[maxIndex] > tree[maxIndex + 1] ? tree[maxIndex] : tree[maxIndex + 1]);</p><p><b>  }</b></p>

40、;<p>  else // 如果不是左子結(jié)點 </p><p><b>  {</b></p><p>  // 用子結(jié)點中較大值代替父結(jié)點 </p><p>  tree[maxIndex / 2] = (tree[maxIndex] > tree[maxIndex - 1] ? tree[maxIndex] : tre

41、e[maxIndex - 1]);</p><p><b>  }</b></p><p>  maxIndex /= 2; // 繼續(xù)處理父結(jié)點 </p><p><b>  }</b></p><p><b>  }</b></p><p><

42、b>  }</b></p><p>  template <class Type></p><p>  void Sort<Type>::AdjustTree(Type ar[],int k,int n) //調(diào)整堆</p><p><b>  {</b></p><p>&l

43、t;b>  int i,j;</b></p><p><b>  i=k;</b></p><p>  j=2*i; //arrau[j]是array[i]的左孩子</p><p>  Type temp=array[i];</p><p>  while(j<=n)</p>&

44、lt;p>  {if(j<n&&array[j]<array[j+1]) //若有孩子較大,把j指向右孩子</p><p><b>  j=j+1;</b></p><p>  if(temp<array[j]) </p><p><b>  {</b></p>&l

45、t;p>  array[i]=array[j]; //array[j]調(diào)整到雙親結(jié)點</p><p><b>  i=j;</b></p><p><b>  j=2*i;</b></p><p><b>  }</b></p><p>  else break;&

46、lt;/p><p><b>  }</b></p><p>  array[i]=temp;</p><p><b>  }</b></p><p>  template <class Type></p><p>  void Sort<Type>::He

47、apSort(Type ar[]) //堆排序</p><p><b>  {</b></p><p><b>  int i;</b></p><p><b>  Type t;</b></p><p>  for(i=len/2;i>=1;i--) //循環(huán)建立

48、初始堆</p><p>  AdjustTree(array,i,len);</p><p>  for(i=len;i>=2;i--) //進行n-1次循環(huán),完成堆排序</p><p>  {t=array[i];</p><p>  array[i]=array[1];</p><p>  array[1

49、]=t;</p><p>  AdjustTree(array,1,i-1);</p><p><b>  }</b></p><p><b>  }</b></p><p>  template<class Type></p><p>  void Sort&l

50、t;Type>::write() //輸入數(shù)組</p><p><b>  {</b></p><p><b>  int i,l;</b></p><p>  printf("請輸入數(shù)組長度:");</p><p>  scanf("%d",&

51、;l);</p><p><b>  len=l;</b></p><p>  printf("請輸入數(shù)組元素:\n");</p><p>  for(i=1;i<=l;i++)</p><p>  cin>>array[i];</p><p><b&g

52、t;  }</b></p><p>  template<class Type></p><p>  void Sort<Type>::print() //輸出數(shù)組</p><p><b>  {int i;</b></p><p>  printf("排序后的數(shù)組為:\n

53、");</p><p>  for(i=1;i<=len;i++)</p><p>  cout<<array[i]<<" ";</p><p>  cout<<endl;</p><p><b>  }</b></p><p&

54、gt;  在類的成員函數(shù)實現(xiàn)過程中,系統(tǒng)會自動為類產(chǎn)生構(gòu)造函數(shù),類的構(gòu)造函數(shù)自動調(diào)用,為類動態(tài)分配了內(nèi)存空間,整個調(diào)用過程中完全是由系統(tǒng)內(nèi)部完成。</p><p>  成員函數(shù)對成員變量進行操作,實現(xiàn)排序功能,通過for( ) 循環(huán),實現(xiàn)輸入輸出數(shù)組元素的功能。</p><p>  4.3 主函數(shù)設(shè)計</p><p>  在程序的主函數(shù)部分,選擇了分別以int、c

55、har和float型為數(shù)據(jù)類型的對象作為實際例子來驗證算法。首先,選擇數(shù)據(jù)類型;然后,通過write( ) 函數(shù)對成員變量數(shù)組array[ ] 進行賦值,通過swich()語句選擇排序方式,用對象調(diào)用對應(yīng)的成員函數(shù)實現(xiàn)數(shù)組排序;最后,通過print()函數(shù)輸出排序后的結(jié)果。</p><p>  void main() //主函數(shù)</p><p>  { int i,j=1;<

56、/p><p>  Sort<int> s;</p><p>  Sort<char> p;</p><p>  Sort<float> z;</p><p>  cout<<"選擇輸入類型:1.int 2.char 3.float"<<endl;</p>

57、;<p><b>  cin>>i;</b></p><p><b>  if(i==1)</b></p><p>  {s.write();</p><p>  cout<<"請選擇排序方式:1.簡單選擇排序 2.樹形選擇排序 3.堆排序"<<endl

58、;</p><p><b>  cin>>i;</b></p><p><b>  switch(i)</b></p><p><b>  {</b></p><p>  case 1:s.SelectSort(s.array);break;</p>

59、<p>  case 2:s.tree_select_sort(s.array,s.len+1);break;</p><p>  case 3:s.HeapSort(s.array);break;</p><p>  default:break;</p><p><b>  }</b></p><p>  s

60、.print();}</p><p>  else if(i==2)</p><p>  {p.write();</p><p>  cout<<"請選擇排序方式:1.簡單選擇排序 2.樹形選擇排序 3.堆排序<<endl";</p><p><b>  cin>>i;<

61、/b></p><p><b>  switch(i)</b></p><p><b>  {</b></p><p>  case 1:p.SelectSort(p.array);break;</p><p>  case 2:p.tree_select_sort(p.array,p.len

62、+1);break;</p><p>  case 3:p.HeapSort(p.array);break;</p><p>  default:break;</p><p><b>  }</b></p><p>  p.print();}</p><p>  else if(i==3)<

63、/p><p>  {z.write();</p><p>  cout<<"請選擇排序方式:1.簡單選擇排序 2.樹形選擇排序 3.堆排序<<endl";</p><p><b>  cin>>i;</b></p><p><b>  switch(i)<

64、;/b></p><p><b>  {</b></p><p>  case 1:z.SelectSort(z.array);break;</p><p>  case 2:z.tree_select_sort(z.array,z.len+1);break;</p><p>  case 3:z.HeapSort

65、(z.array);break;</p><p>  default:break;</p><p><b>  }</b></p><p>  z.print();}</p><p><b>  }</b></p><p>  4.4 基于控制臺的應(yīng)用程序測試</p&

66、gt;<p>  用簡單選擇排序進行int類型的排序</p><p><b>  圖1</b></p><p>  用樹形選擇排序進行char類型的排序</p><p><b>  圖2 </b></p><p> ?。?)用堆排序進行float類型的排序</p><

67、;p><b>  圖3</b></p><p>  5 基于MFC的應(yīng)用程序</p><p>  MFC的圖形界面程序設(shè)計可在上述類設(shè)計的基礎(chǔ)上進行改造,MFC的圖形界面程序與DOS界面程序的主要不同點是:MFC圖形界面程序與DOS界面程序的輸入輸出方式不同,DOS界面程序采用字符交互式實現(xiàn)數(shù)據(jù)輸入輸出,主要通過cin,cout等I/O流實現(xiàn),而MFC的圖形程

68、序界面采用標準Windows窗口和控件實現(xiàn)輸入輸出,因此必須在MFC類的框架下加入上面所設(shè)計的矩陣和方程組類,并通過圖形界面的輸入輸出改造來完成。</p><p>  5.1.1 MFC程序界面設(shè)計</p><p>  首先在VC中建立MFC AppWizard(exe)工程,名稱為1203060128,并在向?qū)У腟tep1中選擇基本對話框,即建立基于對話框的應(yīng)用程序,如下圖4、圖5所示

69、。</p><p>  圖4建立MFC AppWizard(exe)工程</p><p>  圖5 建立基于對話框的應(yīng)用程序</p><p>  將對話框資源中的默認對話框利用工具箱改造成如下界面,如圖6所示。</p><p>  圖6 選擇排序方法的實現(xiàn)界面設(shè)計</p><p>  圖3所示的界面中包含了2個Stat

70、ic Text控件,3個Button控件,和10個Edit Box控件, 控件的基本信息列表如下表1所示。</p><p><b>  表1 控件基本信息</b></p><p>  5.1.2 MFC程序代碼設(shè)計</p><p>  為了能夠?qū)υ捒蚪缑嫔系目丶軌蚺c代碼聯(lián)系起來,需要為10個Edit Box控件建立Member Varia

71、bles,按Ctrl+w鍵進入MFC ClassWizard界面,選擇Member Variables選項卡,可顯示成員變量設(shè)置界面,如圖7所示。</p><p>  圖7 成員變量設(shè)置界面</p><p>  通過該界面設(shè)置與10個Edit Box控件對應(yīng)的成員變量,具體如表2所示。</p><p><b>  表2 控件基本信息</b>&l

72、t;/p><p>  下面是編寫代碼的重要階段</p><p><b>  簡單選擇排序</b></p><p><b>  int a[5];</b></p><p>  UpdateData(true);</p><p>  a[0]=m_l1;</p><

73、;p>  a[1]=m_l2;</p><p>  a[2]=m_l3;</p><p>  a[3]=m_l4;</p><p>  a[4]=m_l5;</p><p>  int i,j,k;</p><p><b>  int temp;</b></p><p&g

74、t;  int len=5;</p><p>  for(i=0;i<=len;i++)</p><p><b>  { k=i;</b></p><p>  for(j=i+1;j<=len;j++)</p><p>  if(a[k]>a[j])</p><p><b

75、>  k=j;</b></p><p><b>  if(k!=i)</b></p><p><b>  {</b></p><p>  temp=a[k];</p><p>  a[k]=a[i];</p><p>  a[i]=temp;</p&g

76、t;<p><b>  }</b></p><p><b>  }</b></p><p>  m_l6=a[0];</p><p>  m_l7=a[1];</p><p>  m_l8=a[2];</p><p>  m_l9=a[3];</p>

77、<p>  m_l10=a[4];</p><p>  UpdateData(false);</p><p><b>  樹形選擇排序</b></p><p><b>  int a[5];</b></p><p>  UpdateData(true);</p><

78、p>  a[0]=m_l1;</p><p>  a[1]=m_l2;</p><p>  a[2]=m_l3;</p><p>  a[3]=m_l4;</p><p>  a[4]=m_l5;</p><p>  char tree[50]; //樹 </p><p&

79、gt;  int max;//最大值</p><p>  int baseSize;</p><p><b>  int i;</b></p><p>  int maxIndex;//最大值的下標</p><p>  int treeSize;//最終這棵樹會達到的大小</p><p>  in

80、t len=5;</p><p>  int MIN_VALUE=0;</p><p>  baseSize=1;</p><p>  while(baseSize<len)</p><p><b>  {</b></p><p>  baseSize*=2;</p><

81、p><b>  }</b></p><p>  treeSize=baseSize*2-1;</p><p>  for(i=0;i<len;i++)</p><p><b>  {</b></p><p>  tree[treeSize-i]=a[i];</p><

82、p><b>  }</b></p><p>  for(;i<baseSize;i++)</p><p><b>  {</b></p><p>  tree[treeSize-i]=MIN_VALUE;</p><p><b>  }//構(gòu)造一棵樹</b><

83、/p><p>  for(i=treeSize;i>1;i-=2)</p><p><b>  {</b></p><p>  tree[i/2]=(tree[i]>tree[i-1]?tree[i]:tree[i-1]);</p><p><b>  }</b></p>&l

84、t;p>  len=len-1;</p><p>  while(len!=-1)</p><p><b>  {</b></p><p>  max=tree[1];</p><p>  a[len--]=max;</p><p>  maxIndex=treeSize;</p>

85、;<p>  while(tree[maxIndex]!=max)</p><p><b>  { </b></p><p>  maxIndex--;</p><p><b>  }</b></p><p>  tree[maxIndex]=MIN_VALUE;</p>

86、<p>  while(maxIndex>1)</p><p><b>  {</b></p><p>  if(maxIndex%2==0)</p><p><b>  {</b></p><p>  tree[maxIndex/2]=(tree[maxIndex]>tr

87、ee[maxIndex+1]?tree[maxIndex]:tree[maxIndex+1]);</p><p><b>  }</b></p><p><b>  else</b></p><p><b>  {</b></p><p>  tree[maxIndex/2]=

88、(tree[maxIndex]>tree[maxIndex-1]?tree[maxIndex]:tree[maxIndex-1]);</p><p><b>  }</b></p><p>  maxIndex/=2;</p><p><b>  }</b></p><p><b>

89、  }</b></p><p>  m_l6=a[0];</p><p>  m_l7=a[1];</p><p>  m_l8=a[2];</p><p>  m_l9=a[3];</p><p>  m_l10=a[4];</p><p>  UpdateData(false);

90、</p><p><b>  堆排序</b></p><p><b>  int a[5];</b></p><p>  UpdateData(true);</p><p>  a[0]=m_l1;</p><p>  a[1]=m_l2;</p><p&

91、gt;  a[2]=m_l3;</p><p>  a[3]=m_l4;</p><p>  a[4]=m_l5;</p><p>  int i=0,j,temp;</p><p><b>  int p=10;</b></p><p><b>  int q=10;</b>

92、;</p><p>  int len=5;</p><p><b>  j=2*p;</b></p><p>  while(j<=q)//堆頂元素下篩</p><p>  {if((j<q)&&(a[j]<a[j+1]))//確定下篩位置</p><p>&l

93、t;b>  ++j;</b></p><p>  temp=a[i];</p><p>  if(temp>a[j])break;</p><p>  a[p]=a[j];p=j;</p><p><b>  j*=2;}</b></p><p>  a[p]=temp;&

94、lt;/p><p>  {temp=a[1];</p><p>  a[1]=a[i];</p><p>  a[i]=temp;}</p><p>  m_l6=a[0];</p><p>  m_l7=a[1];</p><p>  m_l8=a[2];</p><p>

95、  m_l9=a[3];</p><p>  m_l10=a[4];</p><p>  UpdateData(false);</p><p>  5.2基于MFC的應(yīng)用程序測試</p><p>  運行程序后,首先出現(xiàn)的界面如圖8所示。</p><p>  圖8 程序初始運行界面</p><p&g

96、t;  單擊簡單選擇排序按鈕后,可將輸入前的字符進行排序,如圖6所示。</p><p><b>  圖9 排序后的界面</b></p><p><b>  結(jié) 論</b></p><p>  本次課程設(shè)計,在DOS界面中,先用template<class Type>class定義sort模板類,類中數(shù)據(jù)類型用t

97、ype代替,我定義了三個成員函數(shù),SelectSort(),tree_select_sort(),HeapSort(),分別實現(xiàn)對成員變量array[ ]數(shù)組的簡單選擇排序,樹形選擇排序,堆排序,又定義了兩個成員函數(shù)write( ) 和print( ),分別輸入和輸出成員變量,根據(jù)模板類的定義要求,成員函數(shù)都用template<class Type>修飾,使之能適用于多種數(shù)據(jù)類型,而不是局限于一種。我將函數(shù)的聲明與定義分離,

98、在類中聲明函數(shù),在類體外定義函數(shù),是程序清晰易讀。通過努力,程序正確運行,并得到了實驗要求的結(jié)果,說明本次程序?qū)崿F(xiàn)了其主要功能。而我通過本次實驗學到了如何定義模板類,如何使用多種方法為數(shù)組排序。</p><p>  MFC程序與DOS界面程序編寫的最大不同是程序員需要將編程精力放在圖形界面設(shè)計、圖形界面輸入輸出以及界面各種排序的設(shè)計等問題上,而這些問題在DOS界面程序中是不存在的。本次課程設(shè)計作為編寫Window

99、s程序的初步嘗試,能夠?qū)崿F(xiàn)程序的主要功能,可以說是取得了成功,然而好的程序絕不僅僅是只有功能性這一個指標,編寫出一個基于Windows界面的程序時,所獲得的滿足程度遠遠大于簡單的DOS界面程序,本次編寫的MFC程序雖然能實現(xiàn)所需功能,但從面向?qū)ο蟪绦蛟O(shè)計理念和圖形界面設(shè)計要求來說,尚存在不足,主要包括以下幾個方面。</p><p>  本次的MFC程序只能對整型數(shù)組排序,如果改為char型、float型的,需從屬

100、性的對話框中重復(fù)選擇。這樣確實很不實用。作者希望選擇的類型可以自主進行轉(zhuǎn)換</p><p> ?。?)將類的定義與實現(xiàn)放在同一個頭文件中也違背了面向?qū)ο蟪绦蛟O(shè)計理念,需要將二者分開成定義文件和實現(xiàn)文件。</p><p><b>  參考文獻</b></p><p>  [1] 譚浩強. C程序設(shè)計. 北京:清華大學出版社,1991</p&

101、gt;<p>  [2] 鄭振潔C++程序設(shè)計. 北京:人民郵電出版社,2005</p><p>  [3] 柴欣.C/ C++程序設(shè)計. 河北大學出版社,2002</p><p>  [4] 余蘇寧、王明福.C++程序設(shè)計. 北京:高等教育出版社,2003</p><p>  [5] 李云清、楊慶紅、揭安全.數(shù)據(jù)結(jié)構(gòu)[m] .人民郵電大學出版社,20

溫馨提示

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

評論

0/150

提交評論