C语言的快速排序的算法是什么啊?

如题所述

快速排序(Quicksort)是对冒泡排序的一种改进。由C. A. R. Hoare在1962年提出。它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。 算法过程  设要排序的数组是A[0]……A[N-1],首先任意选取一个数据(通常选用第一个数据)作为关键数据,然后将所有比它小的数都放到它前面,所有比它大的数都放到它后面,这个过程称为一趟快速排序。值得注意的是,快速排序不是一种稳定的排序算法,也就是说,多个相同的值的相对位置也许会在算法结束时产生变动。   一趟快速排序的算法是:   1)设置两个变量I、J,排序开始的时候:I=0,J=N-1;   2)以第一个数组元素作为关键数据,赋值给key,即 key=A[0];   3)从J开始向前搜索,即由后开始向前搜索(J=J-1),找到第一个小于key的值A[J],并与key交换;   4)从I开始向后搜索,即由前开始向后搜索(I=I+1),找到第一个大于key的A[I],与key交换;   5)重复第3、4、5步,直到 I=J; (3,4步是在程序中没找到时候j=j-1,i=i+1,直至找到为止。找到并交换的时候i, j指针位置不变。另外当i=j这过程一定正好是i+或j-完成的最后另循环结束。)   例如:待排序的数组A的值分别是:(初始关键数据:X=49) 注意关键X永远不变,永远是和X进行比较,无论在什么位子,最后的目的就是把X放在中间,小的放前面大的放后面。   A[0] A[1] A[2] A[3] A[4] A[5] A[6]:   49 38 65 97 76 13 27   进行第一次交换后:27 38 65 97 76 13 49   ( 按照算法的第三步从后面开始找)   进行第二次交换后:27 38 49 97 76 13 65   ( 按照算法的第四步从前面开始找>X的值,65>49,两者交换,此时:I=3 )   进行第三次交换后:27 38 13 97 76 49 65   ( 按照算法的第五步将又一次执行算法的第三步从后开始找   进行第四次交换后:27 38 13 49 76 97 65   ( 按照算法的第四步从前面开始找大于X的值,97>49,两者交换,此时:I=4,J=6 )   此时再执行第三步的时候就发现I=J,从而结束一趟快速排序,那么经过一趟快速排序之后的结果是:27 38 13 49 76 97 65,即所有大于49的数全部在49的后面,所有小于49的数全部在49的前面。   快速排序就是递归调用此过程——在以49为中点分割这个数据序列,分别对前面一部分和后面一部分进行类似的快速排序,从而完成全部数据序列的快速排序,最后把此数据序列变成一个有序的序列,根据这种思想对于上述数组A的快速排序的全过程如图6所示:   初始状态 {49 38 65 97 76 13 27}   进行一次快速排序之后划分为 {27 38 13} 49 {76 97 65}   分别对前后两部分进行快速排序 {27 38 13} 经第三步和第四步交换后变成 {13 27 38} 完成排序。   {76 97 65} 经第三步和第四步交换后变成 {65 76 97} 完成排序。   
温馨提示:内容为网友见解,仅供参考
第1个回答  2013-09-14
就是一种算法, 算法的时间复杂度为 nlgn。 是一种排序速度很快的算法, 同时也是不稳定排序算法!
第2个回答  2013-09-14
你说的可能是除了冒泡法的方法吧应该是这样的 Array.Sort(数组名)// 把数组升序 Array.Reverse(数组名) //把数组的顺序颠倒 还望采纳

C语言的快速排序的算法是什么啊?
快速排序(Quicksort)是对冒泡排序的一种改进。由C. A. R. Hoare在1962年提出。它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有...

c语言快速排序函数怎么写?
快速排序是高效排序算法之一,由霍尔在1962年提出,其基本思想是选择一个基准值,将序列分为两部分,使得基准值左侧元素小于基准值,右侧元素大于基准值。然后递归对左右子序列进行排序直至有序。快速排序的实现方式主要有三种:1. Hoare版本:选择序列最左侧或最右侧元素作为基准值,经过一次排序后,将基准...

数据结构C语言--三种以上的排序算法
插入排序算法:定义InsertionSort函数,参数为数组a以及排序区间l和r。遍历指定区间,对于每个元素,与已排序的部分进行比较,将大于当前元素的元素向后移动,直到找到当前元素的正确位置,然后将当前元素插入该位置。实现逻辑如下:初始化变量i、j、t,从l+1开始遍历,与已排序的部分比较,执行移动操作,直...

C语言中快速排序法的原理及应用
一般来说,冒泡法是程序员最先接触的排序方法,它的优点是原理简单,编程实现容易,但它的缺点就是--程序的大忌--速度太慢。附上快速排序代码:include<stdio.h>void quicksort(int a[],int left,int right){ int i,j,temp; i=left; j=right; temp=a[left]; if(left>right...

用C语言编写函数实现快速排序(升序),在主函数中输入数组数据,并调用该...
\/\/排序的算法是二分法,N的对数时间复杂度。。。\/\/如果有疑问,我们可以再探讨。。。include<stdlib.h> include<string.h> include<stdio.h> bool merge(int * array,int p,int q,int r){ if(!(p<<q<r)&&p>=0&&r<=sizeof(array)\/sizeof(array[0])-1){ return false;} int * ...

快速排序算法
快速排序(Quicksort)是对冒泡排序的一种改进。然后,左边和右边的数据可以独立排序。对于左侧的数组数据,又可以取一个分界值,将该部分数据分成左右两部分,同样在左边放置较小值,右边放置较大值。右侧的数组数据也可以做类似处理。重复上述过程,可以看出,这是一个递归定义。通过递归将左侧部分排好序...

c语言10个整数快速排序降序
include <stdio.h>void quickSort(int a[],int left,int right)\/\/快速排序法{ int i,j; int k; int t; if(left < right) { i = left; j = right; k = a[left]; while(i < j) { while(i < j && a[j] <= k) j--; while(i < j && a[i] >= k...

数据架构与算法——C\/C++实现快速排序(Quick Sort)算法【建议收藏】
数据架构与算法中,C\/C++语言下快速排序(Quick Sort)是一种常用且高效的排序算法。它基于分治策略,通过一趟排序将数据划分为较小和较大的两部分,然后递归地对这两部分进行排序,最终实现整个数据序列的有序。快速排序的执行流程可以通过一个具体示例来理解,比如数列a={30,40,60,10,20,50}。在排序...

C语言快速排序
\/快速排序算法\/ int Partition(int D[], int l, int r){ D[0]=D[l];while (l<r) { while (l<r && D[0]<D[r]) r--;D[l]=D[r];while (l<r && D[0]>=D[l]) l++;D[r]=D[l]; } D[r]=D[0];return r;} void Qsort(int D[], int l, int r){ int p...

快速排序算法在平均情况下的时间复杂度为 求详解
时间复杂度为O(nlogn) n为元素个数 1. 快速排序的三个步骤:1.1. 找到序列中用于划分序列的元素 1.2. 用元素划分序列 1.3. 对划分后的两个序列重复1,2两个步骤指导序列无法再划分 所以对于n个元素其排序时间为 T(n) = 2*T(n\/2) + n (表示将长度为n的序列划分为两个子序列,每个子...

相似回答
大家正在搜