亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

C++排序算法類匯總

2020-02-24 14:31:17
字體:
來源:轉載
供稿:網友

本篇文章主要是小編為各位剛學習C++的小伙伴們整理的經常用到的東西,我們在平時最常用到的就是排序算法,那么我們現在就跟隨武林小編的腳步一起去參考C++排序算法類匯總吧。

具體代碼如下:

#ifndef SORT_H#define SORT_H#include <iostream>#include <queue>using namespace std;// 1.直接插入排序template<class ElemType>void InsertSort(ElemType data[], int n);// 2.折半插入排序template<class ElemType>void BInsertSort(ElemType data[], int n);// 3.Shell排序// 對data數組中的元素進行希爾排序,n為該數組大小// increments為增量序列,incrementsLength為增量序列的大小template<class ElemType>void ShellSort(ElemType data[],int increments[], int n, int incrementsLength);// 1.Bubble Sorttemplate<class ElemType>void BubbleSort(ElemType data[], int n);// 2.快速排序template<class ElemType>void QuickSort(ElemType data[], int n);////////////////// // Merge Sort////////////////// // 歸并排序template<class ElemType>void MergeSort(ElemType data[],int n);template<class ElemType>void MergeSortNonRecursion(ElemType data[], int n);////////////////// // Selection sort////////////////// // 簡單選擇排序template<class ElemType>void SelectionSort(ElemType data[], int n);// 堆排序template<class ElemType>void HeapSort(ElemType data[],int n);///////////////// Radix Sort///////////////// 靜態鏈表結點const int DIGITS = 10;const int RADIX = 10;class SLList;ostream& operator<<(ostream& os, SLList &s);// 由于VC++6.0使用using namespace std對于友元不支持      // 故在類SLList之前做前向聲明      // 若使用其他C++編譯器,這兩句可刪去// 靜態鏈表static linked list// [0]:頭結點class SLList{ struct Node { int  key[DIGITS]; int    info; int    next; };    friend ostream& operator<<(ostream& os, SLList &s);public: SLList():data(NULL),length(0){};  ~SLList(); void Arrange();         void Init(int arr[],int n);  void RadixSort();private:  void Distribute( int[], int[], int); void Collection( int[], int[], int);  Node *data;  int length;};// 基數排序void RadixSort(int data[], int n);//void RadixSort(SLList&);///////////////// util///////////////template<class ElemType>void Swap( ElemType& a, ElemType& b){  ElemType c = a;  a = b;  b = c;}int init(int** data);template<class ElemType>void print(ElemType data[],int begin,int end);// 直接插入排序,數組data用于存放待排序元素,n為待排序元素個數template<class ElemType>void InsertSort(ElemType data[], int n){   ElemType tmp; int i, j;  for (i = 1; i < n; i++){    if ( data[i] > data[i - 1])      continue;    tmp = data[i];                // 保存待插入的元素 data[i] = data[i - 1];    for ( j = i - 1; j > 0 && data[j - 1] > tmp;j--)      data[j] = data[j - 1];          // 元素后移    data[j] = tmp;                // 插入到正確位置      }}// 折半插入排序template<class ElemType>void BInsertSort(ElemType data[], int n){   ElemType tmp; int i, j, mid, low, high;  for (i = 1; i < n; i++){    tmp = data[i];           // 保存待插入的元素    low = 0;    high = i-1;    while (low <= high){        // 在data[low..high]中折半查找有序插入的位置      mid = (low + high) / 2;      // 折半      if( tmp < data[mid])        high = --mid;         // 插入點在低半區      else        low = ++mid;         // 插入點在高半區    }    for(j = i - 1; j >= low; j--)      data[j + 1] = data[j];     // 元素后移    data[low] = tmp;          // 插入到正確位置  }}// 對data數組中的元素進行希爾排序,n為該數組大小// increments為增量序列,incrementsLength為增量序列的大小template<class ElemType>void ShellSort(ElemType data[], int increments[], int n, int incrementsLength){  int i, j, k;  ElemType tmp; for ( k = 0; k < incrementsLength; k++){    // 進行以increments[k]為增量的排序    for ( i = increments[k]; i < n; i++){      tmp = data[i];      for ( j = i; j >= increments[k]; j -= increments[k]){        if ( tmp >= data[j - increments[k]])          break;         data[j] = data[j - increments[k]];       }      data[j] = tmp;    }  }}// 冒泡排序template<class ElemType>void BubbleSort(ElemType data[], int n){ int lastSwapIndex = n - 1; // 用于記錄最后一次交換的元素下標 int i, j;  for (i = lastSwapIndex; i > 0;i = lastSwapIndex) { lastSwapIndex = 0; for (j = 0; j < i; j++)  if (data[j] > data[j + 1]){        Swap( data[j],data[j + 1]);  lastSwapIndex = j;  } }}//快速排序template<class ElemType>int Partition(ElemType data[] , int low , int high)  {    ElemType pivot = data[low];    while (low < high){      while (low < high && data[high] >= pivot)   high--;      data[low] = data[high];     while (low < high && pivot >= data[low])   low++;      data[high] = data[low];    }    data[low] = pivot;    return low;  }  template<class ElemType>void QuickSort(ElemType data[], int begin, int end){   if (begin >= end)  return;  int pivot = Partition(data , begin , end);    QuickSort(data , begin , pivot - 1);    QuickSort(data , pivot + 1, end);     }template<class ElemType>void QuickSort(ElemType data[], int n){  if (n < 2)    return;  QuickSort(data, 0, n-1);}// 將數組data中,[lptr...rptr-1][rptr...rightEnd]兩部分的元素進行合并// tmpArr為合并時的輔存空間template<class ElemType>void Merge(ElemType data[], ElemType tmpArr[], int lptr, int rptr, int rightEnd){  int leftEnd = rptr - 1;  int ptr,i;  ptr = i = lptr;  while (lptr <= leftEnd && rptr <= rightEnd)    if (data[lptr] <= data[rptr])      tmpArr[ptr++] = data[lptr++];    else      tmpArr[ptr++] = data[rptr++];  while (lptr <= leftEnd)    tmpArr[ptr++] = data[lptr++];  while (rptr <= rightEnd)    tmpArr[ptr++] = data[rptr++];  for (;i <= rightEnd; i++)    data[i] = tmpArr[i];}// 遞歸實現// 將數組data中,[begin...end]的元素進行歸并排序template<class ElemType>void MSort(ElemType data[], ElemType tmpArr[], int begin, int end){  int middle;  if ( begin >= end)    return;  middle = (begin + end)/2;   // 將data平分為[begin..middle]和[middle..end]  MSort( data, tmpArr, begin, middle);  // 遞歸前半部分  MSort( data, tmpArr, middle + 1, end);  // 遞歸后半部分  Merge( data, tmpArr, begin, middle + 1, end); // 將data[begin..middle],data[middle..end]進行歸并}template<class ElemType>void MergeSort(ElemType data[], int n){  ElemType* pArr = NULL;  pArr = new ElemType[n];  MSort( data,pArr,0,n-1);  delete[] pArr;}// 非遞歸實現template<class ElemType>void MPass(ElemType data[], ElemType tmpArr[], int n, int mergeLength){ int i = 0; while (i <= n - 2 * mergeLength){ Merge(data, tmpArr, i, i + mergeLength, i + 2 * mergeLength - 1); i = i + 2 * mergeLength; } if (i + mergeLength < n) Merge(data, tmpArr, i, i + mergeLength, n - 1);}template<class ElemType>void MergeSortNonRecursion(ElemType data[], int n){ int mergeLength = 1; ElemType* pArr = NULL; pArr = new ElemType[n]; while (mergeLength < n){ MPass(data, pArr, n, mergeLength); mergeLength *= 2; } delete[] pArr;}// 簡單選擇排序template<class ElemType>void SelectionSort(ElemType data[], int n){ int i, j, min;  for (i = 0; i < n; i++){    min = i;    for (j = i + 1; j < n; j++){      if ( data[j] < data[min])        min = j;    }    Swap(data[i],data[min]);  }}// 堆排序// i為指定元素在數組中的下標// 返回指定結點的左孩子在數組中的下標inline int LeftChild(int i){  return 2 * i + 1;}template<class ElemType>void HeapAdjust(ElemType data[], int i, int n){  ElemType tmp;  int child;  for ( tmp = data[i]; LeftChild(i) < n; i = child){    child = LeftChild(i);    if (child != n - 1 && data[child + 1] > data[child])  // 取較大的孩子結點      child++;    if (tmp < data[child])                      data[i] = data[child];    else      break;  }  data[i] = tmp;}template<class ElemType>void HeapSort(ElemType data[], int n){  int i;  for (i = n/2; i >= 0; i--)  // 建堆    HeapAdjust(data, i, n);  for (i = n - 1;i > 0; i--){  // 將堆的根結點與最后的一個葉結點交換,并進行調整    Swap(data[0],data[i]);    HeapAdjust(data, 0, i);  }}// 用數組實現的基數排序void RadixSort(int data[], int n){  const int radix = 10;  const int digits = 10;  int i,j,k,factor; queue<int> queues[radix];  for ( i = 0,factor = 1; i < digits;i++,factor *= radix){    for ( j = 0;j < n; j++)      queues[(data[j]/factor)%radix].push(data[j]);    // 分配    for ( k = j = 0; j < radix; j++,k++)          // 收集      while (!queues[j].empty()){        data[k] = queues[j].front();        queues[j].pop();      }  }}// 分配void SLList::Distribute(int front[], int rear[], int digit){ int i, index; for (i = 0; i < RADIX; i++) front[i] = 0; for (i = data[0].next; i > 0; i = data[i].next){ index = data[i].key[digit]; if (front[index] == 0)  front[index] = i; else  data[rear[index]].next = i; rear[index] = i; }}// 收集void SLList::Collection(int front[], int rear[], int digit){ int i, current; for (i = 0; front[i] == 0; i++); // 找到第一個非空子表 data[0].next = front[i];  // 頭結點指向第一個非空子表中第一個結點 current = rear[i++]; for (; i < RADIX; i++){ if (front[i] == 0)  continue; data[current].next = front[i]; // 鏈接兩個非空子表 current = rear[i]; } data[current].next = 0;}// 用SLList實現的基數排序void SLList::RadixSort(){  int i;  int front[RADIX],rear[RADIX];  // 從最低位優先依次對各關鍵字進行分配收集  for ( i = 0; i < DIGITS; i++){    Distribute(front, rear, i);    Collection(front, rear, i);      }}SLList::~SLList(){  delete[] data;  length = 0;}void SLList::Init(int arr[], int n){  length = n + 1;  if (data != NULL)    delete[] data;  data = new Node[n + 1];  data[0].next = 1;  for ( int i = 1; i <= n; i++){    int value = data[i].info = arr[i - 1];    for (int j = 0;j < 10; j++){      data[i].key[j] = value % 10;// + '0';      value /= 10;    }    data[i].next = i + 1;  }  data[n].next = 0;}// 根據鏈表中各結點的指針值調整元素位置,使得SLList中元素按關鍵字正序排列void SLList::Arrange(){ int i, tmp; int current = data[0].next;   // current存放第一個元素的當前位置 for (i = 1; i < length; i++){ while (current < i)   // 找到第i個元素,并用current存放其在靜態鏈表中當前位置  current = data[current].next; tmp = data[current].next; if (current != i){  Swap(data[current], data[i]); // 第i個元素調整到位  data[i].next = current;  // 指向被移走的元素 } current = tmp;    // 為找第i + 1個元素做準備 }}ostream& operator<<(ostream& os,SLList &s){ for (int i = 1; i < s.length; i++) cout << s.data[i].info << " "; os << endl; return os;}#endif

看完C++排序算法類匯總,我們知道C++可實現各種排序算法類,比如直接插入排序、折半插入排序、Shell排序、歸并排序、基數排序、堆排序、用數組實現的基數排序等。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美性生活大片免费观看网址| 亚洲激情视频在线播放| 欧美xxxx14xxxxx性爽| 久久久在线免费观看| 久久久之久亚州精品露出| 欧美超级乱淫片喷水| 欧美大片在线看| 亚洲香蕉伊综合在人在线视看| 亚洲精品动漫久久久久| 日韩成人激情影院| 久久99国产精品久久久久久久久| 亚洲欧美另类自拍| 国产成人精品视| 久久久国产精品视频| 91免费视频网站| 国产精品自拍偷拍| 国产区精品视频| 狠狠色狠狠色综合日日五| 亚洲一品av免费观看| 亚洲精品影视在线观看| 日韩精品在线免费观看| 深夜福利国产精品| 久久久久久成人| 国产婷婷97碰碰久久人人蜜臀| 亚洲视频欧美视频| 亚洲影院污污.| 欧美伦理91i| 久久久www成人免费精品| 久久手机免费视频| 亚洲国产97在线精品一区| 91中文在线视频| 亚洲成人精品久久久| 美女视频黄免费的亚洲男人天堂| 亚洲午夜久久久影院| 国产精品一二三在线| 性色av一区二区三区免费| 最近的2019中文字幕免费一页| 日韩av毛片网| 欧美电影在线观看高清| 国产一区二区三区在线观看网站| 中文字幕日韩av电影| 日韩精品在线免费观看| 日韩精品免费在线播放| 久久国产一区二区三区| 国产精品亚洲视频在线观看| 麻豆乱码国产一区二区三区| 亚洲高清久久网| 亚洲电影免费观看高清完整版在线观看| 亚洲精品色婷婷福利天堂| 自拍偷拍免费精品| 亚洲国内精品在线| 98精品国产高清在线xxxx天堂| 色吧影院999| 国产精品av电影| 欧美中文字幕在线播放| 欧美日韩在线免费| 亚洲成人免费网站| 欧美小视频在线| 国语自产精品视频在线看抢先版图片| 国产aⅴ夜夜欢一区二区三区| 久久综合伊人77777蜜臀| 欧美极品少妇全裸体| 日韩电影在线观看免费| 国产婷婷97碰碰久久人人蜜臀| 九九精品视频在线| 日韩精品视频在线免费观看| 国产极品精品在线观看| 欧美日韩国产限制| 日韩av在线直播| 日韩a**中文字幕| 亚洲欧洲中文天堂| 国产专区欧美专区| 色偷偷偷亚洲综合网另类| 亚洲国产成人久久| 欧美视频在线免费看| 欧美日韩一区二区在线播放| 欧美性猛xxx| 久久大大胆人体| 九九热这里只有精品免费看| 成人久久精品视频| 456亚洲影院| 亚洲视频在线看| 日韩在线高清视频| 青青久久aⅴ北条麻妃| 欧美日韩国产在线播放| 欧美日在线观看| 国产免费一区二区三区在线观看| 疯狂做受xxxx欧美肥白少妇| 亚洲美女黄色片| 在线日韩欧美视频| 久久99久久久久久久噜噜| 亚洲天堂久久av| 欧美俄罗斯乱妇| 精品亚洲va在线va天堂资源站| 亚洲国产精品小视频| www.日韩系列| 国产一区在线播放| 日韩中文字幕精品视频| 欧美激情亚洲视频| 在线一区二区日韩| 69影院欧美专区视频| 亚洲欧美日韩综合| 日韩av在线最新| 欧美一区二区影院| 欧美日韩综合视频| 亚洲欧美日韩图片| 国产精品偷伦视频免费观看国产| 欧美电影免费观看| 国产精品影院在线观看| 欧美国产日韩一区二区| 欧美成人第一页| 91av福利视频| 国产婷婷成人久久av免费高清| 黑人巨大精品欧美一区二区| 欧美老肥婆性猛交视频| 欧美亚洲另类激情另类| 欧美老少做受xxxx高潮| 久久久精品影院| 欧美性猛交99久久久久99按摩| 九九热这里只有在线精品视| 欧美韩日一区二区| 九九视频直播综合网| 久久九九精品99国产精品| 欧美性在线观看| 国产成人免费91av在线| 97成人精品区在线播放| 91chinesevideo永久地址| 精品一区二区三区三区| 日本sm极度另类视频| 久久久成人的性感天堂| 性色av香蕉一区二区| 欧美性xxxxhd| 亚洲图片在线综合| 亚洲伊人久久大香线蕉av| 国产91露脸中文字幕在线| 中文字幕亚洲无线码a| 久久精品91久久久久久再现| 欧美视频第一页| 精品中文字幕视频| 亚洲欧美资源在线| 亚洲自拍偷拍一区| 亚洲视频在线看| 欧美另类老肥妇| 日韩精品免费电影| 日韩av影院在线观看| 97视频免费在线观看| 国产精品久久久久久一区二区| 精品国产鲁一鲁一区二区张丽| 中文字幕亚洲综合| 91在线网站视频| 亚洲xxx自由成熟| 久久久成人精品视频| 久久久精品欧美| 欧美亚洲一区在线| 日韩av免费观影| 亚洲视频在线免费看| 国产精品久久久久9999| 亚洲综合自拍一区| 77777少妇光屁股久久一区| 国产精品久久久久久久久久东京| 亚洲欧美中文日韩在线| 亚洲片在线观看| 国产精品日日做人人爱| 中文字幕亚洲欧美日韩在线不卡|