php专区

 首页 > php专区 > PHP进阶 > 算法 > 快速排序里的学问:随机化快排

快速排序里的学问:随机化快排

分享到:
【字体:
导读:
         摘要:一般来说随机选取枢纽元这种策略非常安全,除非随机数生成器有问题(这不像你所想象的那么罕见),因为随机的枢纽元不可能总在接连不断地产生劣质的分割。另一方面,随机数的生成一般是昂贵的,根本减少不了算法其余部分的平均运行时间。算法与前面《算法导论》里的例子差不多,只是在调用分割Partition时加入一个随机数,具体可以参看...

快速排序里的学问:随机化快排

前一篇文章讲到了选择枢纽元的几种方法,其实第二种是随机选择元素作为枢纽元。那么在这篇文章里就实现一个随机化排序。

算法与前面《算法导论》里的例子差不多,只是在调用分割Partition时加入一个随机数,具体可以参看程序。

C语言代码为:

#include "stdio.h"
#include "math.h"
#include "stdlib.h"

int num = 10;

void swap(int *a,int *b)
{
    int tmp;
    tmp = *a;
    *a = *b;
    *b = tmp;
}

void PrintArray(int arr[])
{
    int i;
	for(i=0; i 

程序运行结果:

初始数组:79 36 68 39 10 96 59 60 84 21
排序过程:79 36 68 39 10 59 60 21 84 96
随机选择 arr[8](84)
排序过程:21 10 36 39 79 59 60 68 [84] 96
随机选择 arr[2](36)
排序过程:10 21 [36] 39 79 59 60 68 84 96
随机选择 arr[1](21)
随机选择 arr[1](21)
随机选择 arr[2](36)
排序过程:10 21 [36] 39 79 59 60 68 84 96
随机选择 arr[3](39)
随机选择 arr[3](39)
排序过程:10 21 36 [39] 68 59 60 79 84 96
随机选择 arr[7](79)
排序过程:10 21 36 39 60 59 68 [79] 84 96
随机选择 arr[6](68)
排序过程:10 21 36 39 59 60 [68] 79 84 96
随机选择 arr[4](59)
随机选择 arr[4](59)
随机选择 arr[6](68)
随机选择 arr[7](79)
随机选择 arr[8](84)
最后结果:10 21 36 39 59 60 68 79 [84] 96
Process returned 0 (0x0)   execution time : 0.582 s
Press any key to continue.

一般来说随机选取枢纽元这种策略非常安全,除非随机数生成器有问题(这不像你所想象的那么罕见),因为随机的枢纽元不可能总在接连不断地产生劣质的分割。另一方面,随机数的生成一般是昂贵的,根本减少不了算法其余部分的平均运行时间。

比如上面程序的运行结果,可以看到,产生了不少随机数是对排序没有产生有效作用的,而产生这些随机数也耗费了不少时间。当然你也可以选择优化随机数生成器,这样又会引起更多的研究了。

延伸阅读

此文章所在专题列表如下:

  1. 快速排序里的学问:从猜数字开始
  2. 快速排序里的学问:再看看称球问题
  3. 快速排序里的学问:信息熵
  4. 快速排序里的学问:快速排序的过程
  5. 快速排序里的学问:霍尔与快速排序
  6. 快速排序里的学问:霍尔快排的实现
  7. 快速排序里的学问:枢纽元选择与算法效率
  8. 快速排序里的学问:随机化快排

本文地址:http://www.nowamagic.net/librarys/veda/detail/2398,欢迎访问原出处。

快速排序里的学问:随机化快排
分享到:
相似图片搜索的原理(一)
相似图片搜索的原理(一)上个月,Google把"相似图片搜索"正式放上了首页。 你可以用一张图片,搜索互联网上所有与它相似的图片。点击搜索框中照相机的图标。 一个对话框会出现。 你输入网片的网址,或者直接上传图片,Google就会找出与其相似的图片。下面这张图片是美国女演员Alyson Hannigan。 上传后,Google返回如下...
快速排序里的学问:枢纽元选择与算法效率
快速排序里的学问:枢纽元选择与算法效率 选择首尾元素做枢纽元 通常的、没有经过充分考虑的选择是将第一个或最后一个元素用作枢纽元。选择第一个元素作为枢纽元的程序例子可以参考专题的前一篇《快速排序里的学问:霍尔快排的实现》,而选择最后一个元素用作枢纽元的程序例子则可以参考《快速排序里的学问:快速排...
  •         php迷,一个php技术的分享社区,专属您自己的技术摘抄本、收藏夹。
  • 在这里……