程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> c說話疾速排序算法示例代碼分享

c說話疾速排序算法示例代碼分享

編輯:關於C++

c說話疾速排序算法示例代碼分享。本站提示廣大學習愛好者:(c說話疾速排序算法示例代碼分享)文章只能為提供參考,不一定能成為您想要的結果。以下是c說話疾速排序算法示例代碼分享正文



步調為:
1.從數列中挑出一個元素,稱為 "基准"(pivot);
2.從新排序數列,一切元素比基准值小的擺放在基准後面,一切元素比基准值年夜的擺在基准的前面(雷同的數可以就任一邊)。在這個分區加入以後,該基准就處於數列的中央地位。這個稱為分區(partition)操作。
3.遞歸地(recursive)把小於基准值元素的子數列和年夜於基准值元素的子數列排序。
遞歸的最底部情況,是數列的年夜小是零或一,也就是永久都曾經被排序好了。固然一向遞歸下去,然則這個算法總會加入,由於在每次的迭代(iteration)中,它至多會把一個元素擺到它最初的地位去。


#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#define RANDOM(i) (rand()%i)
#define N 9    //設置數組長度

//分區操作
int Partition(int array[], int left, int right)
{
 int i,j;
 int temp;
 j = left-1;
 for (i=left; i<=right; i++)
 {
  if (array[i] <=  array[right]) //以最初一個數組的值為基准
  {
   j++;
   temp = array[j];
   array[j] = array[i];
   array[i] = temp;
  }
 }
 return j;
}

//迭代運算
void QuikSort(int array[], int left, int right)
{
 int pivot;
 if (left < right)
 {
  pivot = Partition(array, left, right);
  QuikSort(array, left, pivot-1);
  QuikSort(array, pivot+1, right);
 }
}

//示例
int main()
{
 int i = 0;
 int a[N];
 srand((int)time(0));  //設置隨機數種子

 for (i=0; i<N; i++)  //排序前
 {
  a[i] = RANDOM(100);
  printf("%d\t", a[i]);
 }
 printf("\n\n");

 QuikSort(a, 0, N-1);

 for (i=0; i<N; i++) //排序後
 {
  printf("%d\t", a[i]);
 }
}

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved