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

首頁 > 編程 > C > 正文

7種排序算法的實現示例

2020-01-26 15:31:01
字體:
來源:轉載
供稿:網友

復制代碼 代碼如下:

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

void BubbleSort1 (int n, int *array) /*little > big*/
{
 int i, j;
 for (i=0; i<n-1; i++)
 {
  for (j=n-1; j>i; j--)
  {
   if (array[j] < array[j-1])
   {
    int temp = array[j];
    array[j] = array[j-1];
    array[j-1] = temp;
   }
  }
 }
}

void BubbleSort2 (int n, int *array)
{
 int i, j, flag=1; /*flag=1表示需要繼續冒泡*/
 for (i=0; i<n-1 && flag; i++)
 {
  flag = 0;
  for (j=n-1; j>i; j--)
  {
   if (array[j] < array[j-1])
   {
    int temp = array[j];
    array[j] = array[j-1];
    array[j-1] = temp;
    flag = 1;
   }
  }
 }
}

void SelectSort (int n, int *array)
{
 int i, j, min;
 for (i=0; i<n-1; i++)
 {
  min = i;
  for (j=i+1; j<n; j++)
  {
   if (array[min] > array[j])
    min = j;
  }
  int temp = array[min];
  array[min] = array[i];
  array[i] = temp;
 }
}

void InsertSort (int n, int*array)
{
 int i, j;
 for (i=1; i<n; i++)
 {
  if (array[i] < array[i-1]) /*是否需要插入*/
  {
   int key = array[i]; //哨兵
   for (j = i-1;j>=0 && array[j] > key; j--)
   {
    array[j+1] = array[j];
   }
   /*循環結束時array[j]<=key,將key插入到j+1處*/
   array[j+1] = key;
  }
 }
}

/*分組插入排序*/
void ShellSort (int n, int *array)
{
 int i, j;
 int increment;
 for (increment=n/2; increment > 0; increment /= 2)
 {
  for (i=0; i<increment; i++)  /*下面對一組序列進行插入排序*/
  {
   for (j=i+increment; j<n; j+=increment)
   {
    if (array[j] < array[j-increment])
    {
     int key = array[j];
     int k;
     for (k=j-increment; k>=0 && array[k]>key; k -= increment)
     {
      array[k+increment] = array[k];
     }
     array[k+increment] = key;
    }
   }
  }
 }
}

/*分治法*/
void QuickSort (int left, int right, int *array)
{
 if(left>=right)
  return ;
 int i=left, j=right;
 int key=array[i];
 while (i<j)
 {
  while (i<j && array[j]>=key)
   j--;
  array[i] = array[j];
  while (i<j && array[i]<=key)
   i++;
  array[j] = array[i];
 }
 array[i] = key;
 QuickSort(left, i-1, array);
 QuickSort(i+1, right, array);
}

/*array[start+1] ~ array[end]已經滿足堆的定義,調整使得array[start] ~ array[end]滿足堆定義*/
void HeapAdjust (int start, int end, int array[])
{
 int i;
 int temp = array[start]; /*產生第一個空白*/
 for (i=2*start+1; i<=end; i=2*i+1)  /*每次循環時空白節點為array[(i-1)/2]*/
 {
  if (i<end && array[i] < array[i+1])  /*在左右孩子中尋找較大值*/
   i++;
  if (array[i] > temp)
   array[(i-1)/2] = array[i];
  else
   break;
 }
 array[(i-1)/2] = temp;  /*插入原來的temp到空白處*/
}
void HeapSort (int n, int array[])
{
 int i;
 for (i=(n-2)/2; i>=0; i--)  /*構造大頂堆*/
  HeapAdjust(i, n-1, array);

 for (i=n-1; i>0; i--)
 {
  int t = array[i]; /*將根節點交換到數組末端*/
  array[i] = array[0];
  array[0] = t;

  HeapAdjust(0, i-1, array); /*重新調整堆*/
 }
}

/*array[s…m]和array[m+1…t]均已各自有序,合并使得array[s…t]有序*/
void Merge(int s, int m, int t, int *array)
{
 int temp[t-s+1];
 int i=s, j=m+1, k=0;
 while(i<=m && j<=t)
 {
  if(array[i] < array[j])
   temp[k++] = array[i++];
  else
   temp[k++] = array[j++];
 }
 while(i<=m)
  temp[k++] = array[i++];
 while(j<=t)
  temp[k++] = array[j++];

 for(i=s, k=0; i<=t && k<=t-s; i++, k++)
 {
  array[i] = temp[k];
 }
}
void MSort (int s, int t, int *array) /*遞歸調用*/
{
 if(s == t)
  return ;
 int m = (s+t)/2;
 MSort(s, m, array);
 MSort(m+1, t, array);
 Merge(s, m, t, array);
}
void MergeSort1(int n, int *array)
{
 MSort(0, n-1, array);
}
void MergeSort2(int n, int *array) /*非遞歸實現歸并排序*/
{
 int k, i;
 for (k=1; 2*k<n; k *= 2) /*設置每段待歸并的有序序列的長度:1,2,4,8,16……*/
 {
  for (i=0; i+k-1<n; i += 2*k) /*考慮待歸并的左右兩段序列,[i+k-1]是左序列末尾元素下標*/
  {        /*[end=i+2*k-1]是右序列末尾元素下標,end不應該超過n-1*/
   int end=i+2*k-1;
   if(end > n-1)
    end = n-1;
   Merge(i, i+k-1, end, array);
  }
 }
}


int main()
{
 long start, stop;
 int n;
 printf("下面比較幾個時間復雜度為NlogN的排序算法效率高低,其他3個低效率的排序就不考慮了/n");
 printf("輸入待排序數量(int類型表示,在我的機器上超過100萬就可能溢出):/n");
 scanf("%d", &n);
 int a[n], i;

 for(i=0; i<n; i++)
  a[i] = rand()%n;
 start = clock();
 ShellSort(n, a);
 stop = clock();
 printf("希爾排序%d個數據花費時間為: %ldms/n", n, (stop-start)*1000/CLOCKS_PER_SEC);

 for(i=0; i<n; i++)
  a[i] = rand()%n;
 start = clock();
 HeapSort(n, a);
 stop = clock();
 printf("堆排序%d個數據花費時間為: %ldms/n", n, (stop-start)*1000/CLOCKS_PER_SEC);

 for(i=0; i<n; i++)
  a[i] = rand()%n;
 start = clock();
 MergeSort1(n, a);
 stop = clock();
 printf("遞歸式歸并排序%d個數據花費時間為: %ldms/n", n, (stop-start)*1000/CLOCKS_PER_SEC);

 for(i=0; i<n; i++)
  a[i] = rand()%n;
 start = clock();
 MergeSort2(n, a);
 stop = clock();
 printf("非遞歸式歸并排序%d個數據花費時間為: %ldms/n", n, (stop-start)*1000/CLOCKS_PER_SEC);

 for(i=0; i<n; i++)
  a[i] = rand()%n;
 start = clock();
 QuickSort(0, n-1, a);
 stop = clock();
 printf("快速排序%d個數據花費時間為: %ldms/n", n, (stop-start)*1000/CLOCKS_PER_SEC);

/* for(i=0; i<n; i++)
 {
  printf("%d ", a[i]);
 }
*/
 return 0;
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
www.国产精品一二区| 亚洲精品自拍偷拍| 亚洲一区二区三区四区在线播放| 国产精品久久久久久av| 成人黄色av免费在线观看| 国产精品亚洲视频在线观看| 国产视频亚洲视频| 欧美裸体xxxx| 性色av一区二区三区红粉影视| 91国产视频在线| 国产视频久久久久久久| 热久久免费国产视频| 日韩电影免费观看在线| 欧美视频免费在线观看| 久久综合五月天| 亚洲欧美色图片| 日韩精品在线电影| 精品久久久久久久久久久久| 这里精品视频免费| 国产精品欧美日韩一区二区| 亚洲精品国产精品久久清纯直播| 亚洲精品乱码久久久久久按摩观| 精品久久久999| 自拍偷拍亚洲精品| 欧美日韩成人黄色| 欧美老女人www| 国产偷亚洲偷欧美偷精品| 午夜欧美不卡精品aaaaa| 国产美女高潮久久白浆| 成人欧美在线观看| www.久久久久久.com| 成人国产精品久久久| 欧美精品制服第一页| 深夜福利亚洲导航| 欧美一级大片在线免费观看| 国产拍精品一二三| 欧美理论电影在线播放| 成人在线视频福利| 久久手机精品视频| 91高清在线免费观看| 国产精品久久视频| 日韩一区二区三区xxxx| 久久久电影免费观看完整版| 日韩av在线影院| 美女视频久久黄| 最好看的2019年中文视频| 国产精品爽爽爽爽爽爽在线观看| 国产精品入口免费视频一| 中文字幕日韩欧美在线视频| 国产剧情日韩欧美| 91色p视频在线| 国产97在线|亚洲| 久久精品久久久久久| 国产综合在线观看视频| 欧美黑人又粗大| 日韩精品视频在线免费观看| 欧美另类69精品久久久久9999| 国产国产精品人在线视| 欧美又大又粗又长| 国产精品成人aaaaa网站| 国产va免费精品高清在线| 精品久久久久久电影| 亚洲国产精品成人va在线观看| 欧美插天视频在线播放| 国产精品日韩欧美综合| 欧美国产日韩一区二区| 在线观看精品国产视频| 欧美日韩另类字幕中文| 欧美激情免费看| 深夜福利91大全| 欧美床上激情在线观看| 午夜精品久久久久久久男人的天堂| 欧美在线播放视频| 日韩在线一区二区三区免费视频| 国产精品美女网站| 日韩中文字幕av| 亚洲人成电影在线观看天堂色| 亚洲人成网站在线播| 日本19禁啪啪免费观看www| 国产精品1区2区在线观看| 亚洲国产成人精品一区二区| 亚洲最大的网站| 亚洲精品免费一区二区三区| 久久99精品久久久久久噜噜| 亚洲精品自产拍| 日韩在线免费视频| 全色精品综合影院| 精品亚洲男同gayvideo网站| 久久色免费在线视频| 亚洲国产精品网站| 91精品国产高清久久久久久久久| 亚洲第一区第一页| 久久亚洲精品毛片| 亚洲欧美精品在线| 亚洲精品久久久久中文字幕二区| 国产精品欧美一区二区三区奶水| 国产精品中文在线| 国产精品久久久久7777婷婷| 亚洲福利视频二区| 欧美影院成年免费版| 国产精品高清在线| 国内精品免费午夜毛片| 欧美日韩在线观看视频| 欧美黑人巨大xxx极品| 亚洲自拍小视频| 日韩免费中文字幕| 国内精品久久久| 欧美黑人一区二区三区| 国产日韩在线视频| 91地址最新发布| 97在线免费观看| 亚洲精品久久久一区二区三区| 欧美视频在线观看免费| 97超碰蝌蚪网人人做人人爽| 91精品在线国产| 成人黄色免费片| 欧美国产欧美亚洲国产日韩mv天天看完整| 色综合久久88色综合天天看泰| 欧美成人在线网站| 久久人人爽人人爽爽久久| 日韩精品免费一线在线观看| 神马国产精品影院av| 欧美最猛黑人xxxx黑人猛叫黄| 日韩一区视频在线| 欧美黄色片免费观看| 欧美一级电影免费在线观看| 国产成人亚洲综合91| 亚洲人午夜精品免费| 久久久精品视频在线观看| 91人成网站www| 亚洲精品国产综合区久久久久久久| 亚洲四色影视在线观看| 91高清免费在线观看| 热久久美女精品天天吊色| 成人乱人伦精品视频在线观看| 黑人巨大精品欧美一区二区免费| 午夜精品久久久久久久白皮肤| 国产高清在线不卡| 日韩av电影中文字幕| 亚洲精品ady| 日韩中文在线不卡| 久久免费观看视频| 国产日韩在线看片| 国产精品成人国产乱一区| 欧美极品少妇xxxxⅹ喷水| 亚洲激情久久久| 欧美成人激情视频| 久久精品一偷一偷国产| 久久影院资源站| 美女精品久久久| 国产精品女人久久久久久| 黑人巨大精品欧美一区二区| 国产精品视频xxx| 最好看的2019年中文视频| 国产成人精品免费久久久久| 自拍视频国产精品| 色综合久久88| 日韩中文字幕在线观看| 国产成人激情小视频| 欧美成人亚洲成人| 国内外成人免费激情在线视频| 亚洲三级免费看| 国产精品国产三级国产专播精品人| 欧美电影免费观看电视剧大全|