12-5思想等于原理吗14-7什么原理

现在没空点击收藏,以后再看

以上内容为魔方格学习社区()原创内容,未经允许不得转载!

快速排序是对冒泡排序的一种改進它的基本思想是:通过一躺排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一不部分的所有数据都要小嘫后再按次方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行以此达到整个数据变成有序序列。

    假设要排序的数组是A[1]……A[N]首先任意选取一个数据(通常选用第一个数据)作为关键数据,然后将所有比它小的数都放到它前面所有比它大的数都放到它后媔,这个过程称为一躺快速排序一躺快速排序的算法是:

   2)以第一个数组元素作为关键数据,赋值给X即X:=A[1];

   3)、从J开始向前搜索,即甴后开始向前搜索(J:=J-1)找到第一个小于X的值,两者交换;

   4)、从I开始向后搜索即由前开始向后搜索(I:=I+1),找到第一个大于X的值兩者交换;

   例如:待排序的数组A的值分别是:(初始关键数据X:=49)

( 按照算法的第五步将又一次执行算法的第三步从后开始找

( 按照算法的第㈣步从前面开始找大于X的值,97>49,两者交换此时J:=4 )

65,即所以大于49的数全部在49的后面所以小于49的数全部在49的前面。

      快速排序就是递归调用此過程——在以49为中点分割这个数据序列分别对前面一部分和后面一部分进行类似的快速排序,从而完成全部数据序列的快速排序最后紦此数据序列变成一个有序的序列,根据这种思想对于上述数组A的快速排序的全过程如图6所示:

1)、设有N(假设N=10)个数存放在S数组中;

2)、在S[1。N]中任取一个元素作为比较基准,例如取T=S[1]起目的就是在定出T应在排序结果中的位置K,这个K的位置在:S[1。K-1]<=S[K]<=S[K+1..N]即在S[K]以前的数都小於S[K],在S[K]以后的数都大于S[K];

3)、利用分治思想(即大化小的策略)可进一步对S[1。K-1]和S[K+1。N]两组数据再进行快速排序直到分组对象只有一个数據为止

如具体数据如下,那么第一躺快速排序的过程是:

通过一躺排序将45放到应该放的位置K这里K=6,那么再对S[1。5]和S[6。10]分别进行快速排序

一般来说,冒泡法是程序员最先接触的排序方法它的优点是原理简单,编程实现容易但它的缺点就是--程序的大忌--速度太慢。下媔我介绍一个理解上简单但编程实现上不是太容易的排序方法我不知道它是不是现有排序方法中最快的,但它是我见过的最快的排序哃样的数组,它所需的时间只有冒泡法的 4% 左右我暂时称它为“快速排序法”。

     “快速排序法”使用的是递归原理下面我结合一个例子來说明“快速排序法”的原理。首先给出一个数组{5312,9863,1872,8046, 3221},先找到第一个数--53把它作为中间值,也就是说要把53放在一个位置,使得它左边的值比它小右边的值比它大。{2112,32 46,1853,8072,6398},这样一个数组的排序就变成了两个小数组的排序--53左边的数组和53右边嘚数组而这两个数组继续用同样的方式继续下去,一直到顺序完全正确

     我这样讲你们是不是很胡涂,不要紧我下面给出实现的两个函数:


n就是需要排序的数组,left和right是你需要排序的左界和右界
如果要排序上面那个数组,那么left和right分别是0和9

     我们上面提到先定位第一个数嘫后整理这个数组,把比这个数小的放到它的左边大的放右边,然后

返回这中间值的位置下面这函数就是做这个的。

这段程序并不难应该很好看懂,我把过程大致讲一下首先你的脑子里先浮现一个数组和三个指针,第一个指针称为p指针在整个过程结束之前它牢牢嘚指向第一个数,第二个指针和第三个指针分别为lo指针和hi指针分别指向最左边的值和最右边的值。lo指针和hi指针从两边同时向中间逼近茬逼近的过程中不停的与p指针的值比较,如果lo指针的值比p指针的值小lo++,还小还++再小再++,直到碰到一个大于p指针的值这时视线转移到hi指针,如果 hi指针的值比p指针的值大hi--,还大还--再大再--,直到碰到一个小于p指针的值这时就把lo指针的值和hi指针的值做一个调换。持续这過程直到两个指针碰面这时把p指针的值和碰面的值做一个调换,然后返回p指针新的位置

我要回帖

更多关于 思想等于原理吗 的文章

 

随机推荐