久久国产成人av_抖音国产毛片_a片网站免费观看_A片无码播放手机在线观看,色五月在线观看,亚洲精品m在线观看,女人自慰的免费网址,悠悠在线观看精品视频,一级日本片免费的,亚洲精品久,国产精品成人久久久久久久

分享

各類排序C++實(shí)現(xiàn)(冒泡,,選擇,,插入,快排,,歸并,,堆排)

 kylin_1983 2014-08-14

沒有加什么模板之類的,全用的int型,,下標(biāo)有的從0開始有的從1開始

1.插入

  1. #include <iostream>  
  2. #include <cstdio>  
  3. #define N 1005  
  4. using namespace std;  
  5. int n, a[N];  
  6. void InsertSort(int a[], int n) //下標(biāo)從0開始  
  7. {  
  8.     int i, j, temp;  
  9.     for(i = 1; i < n; i++)  
  10.     {  
  11.         temp = a[i];  
  12.         for(j = i; j > 0 && temp < a[j - 1]; j--) a[j] = a[j - 1];  
  13.         a[j] = temp;  
  14.     }  
  15. }  
  16. int main()  
  17. {  
  18.     int i;  
  19.     scanf("%d", &n);  
  20.     for(i = 0; i < n; i++) scanf("%d", &a[i]);  
  21.     InsertSort(a, n);  
  22.     for(i = 0; i < n; i++) printf("%d\n", a[i]);  
  23.     return 0;  
  24. }  


2.選擇


  1. #include <iostream>  
  2. using namespace std;  
  3. int a[105];  
  4. //下標(biāo)從1開始  
  5. void SelectSort(int a[], int n)  
  6. {  
  7.     int i, j, pos;  
  8.     for(i = 1; i < n; i++)  
  9.     {  
  10.         pos = i;  
  11.         for(j = i; j <= n; j++)  
  12.         {  
  13.             if(a[j] < a[pos])  
  14.             pos = j;  
  15.         }  
  16.         int temp = a[pos];  
  17.         a[pos] = a[i];  
  18.         a[i] = temp;  
  19.     }  
  20. }  
  21. int main()  
  22. {  
  23.     int n, i;  
  24.     cin >> n;  
  25.     for(i = 1; i <= n; i++) cin >> a[i];  
  26.     SelectSort(a, n);  
  27.     for(i = 1; i <= n; i++)  
  28.     cout << a[i] << " ";  
  29.     cout << endl;  
  30.     return 0;  
  31. }  


3.冒泡

  1. #include <iostream>  
  2. using namespace std;  
  3. int a[105];  
  4. //下標(biāo)從1開始  
  5. void BubbleSort(int a[], int n)  
  6. {  
  7.     int i, j;  
  8.     for(i = 1; i < n; i++)  
  9.     {  
  10.         for(j = 1; j <= n - i; j++)  
  11.         {  
  12.             if(a[j] > a[j + 1])  
  13.             {  
  14.                 int temp = a[j + 1];  
  15.                 a[j + 1] = a[j];  
  16.                 a[j] = temp;  
  17.             }  
  18.         }  
  19.     }  
  20. }  
  21. int main()  
  22. {  
  23.     int n, i;  
  24.     cin >> n;  
  25.     for(i = 1; i <= n; i++)  
  26.         cin >> a[i];  
  27.     BubbleSort(a, n);  
  28.     for(i = 1; i <= n; i++)  
  29.     cout << a[i] << " ";  
  30.     cout << endl;  
  31.     return 0;  
  32. }  


4.快排

  1. #include <iostream>  
  2. using namespace std;  
  3. int n;  
  4. int a[105];  
  5. //下標(biāo)從0開始  
  6. int partition(int a[], int low, int high)  
  7. {//快速排序中的一趟  
  8.     int key;//作為樞軸來使用  
  9.     key = a[low];  
  10.     while(low < high)  
  11.     {  
  12.         while(low < high && a[high] >= key)  
  13.         --high;  
  14.         a[low] = a[high];  
  15.         while(low < high && a[low] <= key)  
  16.         ++low;  
  17.         a[high] = a[low];  
  18.     }  
  19.     a[low] = key;  
  20.     return low;  
  21. }  
  22. void qsort(int a[], int low, int high)  
  23. {//快速排序的遞歸形式  
  24.     int loc;  
  25.     if(low < high)  
  26.     {  
  27.         loc = partition(a, low, high);//一趟排序結(jié)果的調(diào)用  
  28.         qsort(a, low, loc - 1);  
  29.         qsort(a, loc + 1, high);  
  30.     }  
  31. }  
  32. int main()  
  33. {  
  34.     int i;  
  35.     cin >> n;  
  36.     for(i = 0; i < n; i++) cin >> a[i];  
  37.     qsort(a, 0, n - 1);  
  38.     for(i = 0; i < n; i++) cout << a[i] << " ";  
  39.     cout << endl;  
  40.     return 0;  
  41. }  


5.歸并

  1. #include <iostream>  
  2. #define N 105  
  3. using namespace std;  
  4. int n;  
  5. int a[N], t[N];  
  6. /* 歸并 */  
  7. //下標(biāo)從0開始  
  8. void Merge(int a[], int l, int m, int r)  
  9. {  
  10.     /* p指向輸出區(qū)間 */  
  11.     int p = 0;  
  12.     /* i,、j指向2個(gè)輸入?yún)^(qū)間 */  
  13.     int i = l, j = m + 1;  
  14.     /* 2個(gè)輸入?yún)^(qū)間都不為空時(shí) */  
  15.     while(i <= m && j <= r)  
  16.     {/* 取關(guān)鍵字小的記錄轉(zhuǎn)移至輸出區(qū)間 */  
  17.         if (a[i] > a[j])  
  18.             t[p++] = a[j++];  
  19.         else  
  20.             t[p++] = a[i++];  
  21.     }  
  22.     /* 將非空的輸入?yún)^(qū)間轉(zhuǎn)移至輸出區(qū)間 */  
  23.     while(i <= m) t[p++] = a[i++];  
  24.     while(j <= r) t[p++] = a[j++];  
  25.     /* 歸并完成后將結(jié)果復(fù)制到原輸入數(shù)組 */  
  26.     for (i = 0; i < p; i++)  
  27.         a[l + i] = t[i];  
  28. }  
  29.   
  30. /* 歸并排序 */  
  31. void MergeSort(int a[], int l, int r)  
  32. {  
  33.     int m;  
  34.     if (l < r)  
  35.     {/* 將長度為n的輸入序列分成兩個(gè)長度為n/2的子序列 */  
  36.         m = (l + r) / 2;  
  37.         /* 對兩個(gè)子序列分別進(jìn)行歸并排序 */  
  38.         MergeSort(a, l, m);  
  39.         MergeSort(a, m + 1, r);  
  40.         /* 將2個(gè)排好的子序列合并成最終有序序列 */  
  41.         Merge(a, l, m, r);  
  42.     }  
  43. }  
  44. int main()  
  45. {  
  46.     int i;  
  47.     cin >> n;  
  48.     for(i = 0; i < n; i++) cin >> a[i];  
  49.     MergeSort(a, 0, n - 1);  
  50.     for(i = 0; i < n; i++) cout << a[i] << " ";  
  51.     cout << endl;  
  52.     return 0;  
  53. }  


6.堆排

  1. #include <iostream>  
  2. using namespace std;  
  3. int n;  
  4. int a[105];  
  5. //下標(biāo)從1開始  
  6. void HeapAdjust(int A[], int a, int z)   
  7. {  
  8.     int i, j;  
  9.     for(i = a, j = 2 * i; j <= z; i = j, j = 2 * i)  
  10.     { //i為父,j為子  
  11.         if(j < z && A[j + 1] > A[j]) j++;   //大頂堆,,沿大孩子方向下行  
  12.         if(A[i] < A[j])  
  13.             swap(A[i], A[j]);  
  14.         else break;  
  15.     }  
  16. }  
  17. void HeapSort(int A[], int n)  
  18. {  
  19.     int i;  
  20.     for(i = n / 2; i >= 1; i--) //從倒數(shù)第一個(gè)非葉子結(jié)點(diǎn),,自下而上堆化  
  21.         HeapAdjust(A, i, n);  
  22.     for(i = n; i > 1; i--)  
  23.     { //交換A[1]與最后元素A[i](i=n, ..., 1), 再堆化  
  24.         swap(A[1], A[i]);  
  25.         HeapAdjust(A, 1, i - 1);  
  26.     }  
  27. }  
  28. int main()  
  29. {  
  30.     int i;  
  31.     cin >> n;  
  32.     for(i = 1; i <= n; i++)  
  33.     cin >> a[i];  
  34.     HeapSort(a, n);  
  35.     for(i = 1; i <= n; i++) cout << a[i] << " ";  
  36.     cout << endl;  
  37.     return 0;  
  38. }  


    本站是提供個(gè)人知識管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,,不代表本站觀點(diǎn),。請注意甄別內(nèi)容中的聯(lián)系方式,、誘導(dǎo)購買等信息,謹(jǐn)防詐騙,。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,,請點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多