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

首頁 > 編程 > C > 正文

排序算法的實現示例分享

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

現在寫排序算法的博客非常多,而排序又是我們在編程過程中經常遇到的操作,很大程度上影響了程序的運行,現在我們就去看看排序算法的實現示例分享。

 

#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
欧美激情第三页| 欧美裸体xxxxx| 精品国产福利在线| 日韩精品在线视频观看| 久久777国产线看观看精品| 91麻豆桃色免费看| 国模精品系列视频| 欧美极品欧美精品欧美视频| 日本高清不卡在线| 日韩高清av一区二区三区| 日韩成人中文字幕| 国产+成+人+亚洲欧洲| 精品久久久999| 亚洲最大av网站| 91国产视频在线播放| 国产在线观看一区二区三区| 麻豆成人在线看| 亚洲色图在线观看| 在线看国产精品| 久久久精品欧美| 欧美乱大交xxxxx另类电影| 欧美色视频日本高清在线观看| 影音先锋欧美在线资源| 在线观看日韩欧美| 在线精品视频视频中文字幕| 日韩精品在线观看一区二区| 亚洲国语精品自产拍在线观看| 国产精品第七十二页| 国产99视频精品免视看7| 91po在线观看91精品国产性色| 亚洲成人网久久久| 91社区国产高清| 亚洲天堂av在线播放| 成人网欧美在线视频| 国产日韩欧美视频在线| 亚洲国产91精品在线观看| 国产精品久久久久久婷婷天堂| 国产精品久久久久久久久久久久| 午夜精品久久久久久久99热| 欧美福利在线观看| 日韩高清av一区二区三区| 精品国产欧美一区二区三区成人| 亚洲国产99精品国自产| 91麻豆国产精品| 亚洲天堂开心观看| 欧美激情日韩图片| 欧美精品福利视频| 国产精品美女主播在线观看纯欲| 国产在线日韩在线| 国产日韩欧美一二三区| 亚洲免费高清视频| 一本色道久久88综合日韩精品| 精品国产91久久久| 亚洲精品天天看| 精品国产依人香蕉在线精品| 欧美视频在线视频| 亚洲国产精品小视频| 欧美高清理论片| 色综合久久久888| 国产91精品网站| 欧美成人午夜剧场免费观看| 日韩免费在线电影| 国产成人精品免费久久久久| 日韩高清电影免费观看完整| 国产美女精品视频免费观看| 成人黄色影片在线| 91精品国产一区| 国产一区二区三区在线免费观看| 在线精品播放av| 久久不射电影网| 一区二区三区天堂av| 韩国视频理论视频久久| 日韩在线一区二区三区免费视频| 69av在线视频| 久久久极品av| 日韩电影中文 亚洲精品乱码| 国产69精品99久久久久久宅男| 国产精品一区二区久久国产| 亚洲女人被黑人巨大进入| 在线精品高清中文字幕| 久久久伊人日本| 欧美激情亚洲国产| 成人免费网站在线看| 亚洲精品国产精品国自产在线| 国产精品盗摄久久久| 成人情趣片在线观看免费| 伦伦影院午夜日韩欧美限制| 国产精品jvid在线观看蜜臀| 国产精品视频免费观看www| 国产极品jizzhd欧美| 亚洲精品国产福利| 97精品国产91久久久久久| 中文字幕精品久久久久| 在线电影中文日韩| 亚洲二区中文字幕| 青青久久av北条麻妃黑人| 久久伊人精品一区二区三区| 欧美性精品220| 97在线视频国产| 亚洲国产精品美女| 久久国产精品久久久久久| 亚洲国产私拍精品国模在线观看| 一区二区三区国产视频| 午夜免费在线观看精品视频| 国产精品视频成人| 日韩精品一区二区三区第95| 奇米成人av国产一区二区三区| 91性高湖久久久久久久久_久久99| 久久国产精品电影| 欧美综合第一页| 色偷偷91综合久久噜噜| 国产精品一区二区久久久久| 亚洲天堂一区二区三区| 国产盗摄xxxx视频xxx69| 97超级碰在线看视频免费在线看| 日韩免费观看av| 欧美极品美女电影一区| 亚洲欧洲视频在线| 91最新国产视频| 久久高清视频免费| 亚洲最新av网址| 91精品久久久久久久久不口人| 国产精品视频自在线| 狠狠色香婷婷久久亚洲精品| 国产成人鲁鲁免费视频a| 国产一区二区黑人欧美xxxx| 亚洲精品久久久久中文字幕二区| 亚洲色图校园春色| 亚洲网站在线播放| 亚洲在线观看视频网站| 国产精品视频资源| 亚洲国产成人久久综合一区| 久久99精品视频一区97| 北条麻妃久久精品| 亚洲三级 欧美三级| 亚洲大尺度美女在线| 日本精品一区二区三区在线播放视频| 97在线视频精品| 欧美日韩免费观看中文| 欧美高清理论片| 国产午夜精品一区理论片飘花| 欧美性感美女h网站在线观看免费| 国产精品福利无圣光在线一区| 亚洲精品短视频| 亚洲高清av在线| 日本午夜在线亚洲.国产| 一区二区中文字幕| 国产精品嫩草影院一区二区| 国产日韩中文字幕| 欧美日韩激情网| 亚洲日韩欧美视频| 日韩福利在线播放| 欧美高清在线播放| 欧美夫妻性生活视频| 亚洲一区亚洲二区亚洲三区| 久久久亚洲天堂| 91精品国产乱码久久久久久蜜臀| 草民午夜欧美限制a级福利片| 欧美有码在线视频| 欧美日韩爱爱视频| 欧美激情在线视频二区| 亚洲影院色在线观看免费| 色琪琪综合男人的天堂aⅴ视频| 国产精品爽爽爽|