算法研究之快速排序

快 速排序(Quicksort)是对冒泡排序的一种改进。由C. A. R. Hoare在1962年提出。它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然 后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。
以上摘自百度百科.
最坏时间复杂度:
O(n二次方);
最好时间复杂度:
O(n);
快速排序的基本思想
1.分解:
在D[i...j...n]的数据中,找一个基准点D[j],将数据划分成左右两份,
左等于D[i...j-1]
右等于D[j+1...n]
2.求解
递归调用划分函数 对左右区间两个数据划分求解.
3.合并左右两个排序好的数据
可见快速排序算法时间复杂度等于划分所花费的时间.
下面详细说一说关键的第二部 求解

划分步骤
数据 D[low...high];
① 设两个变量 i,j,分别指向数据的low 和high.取其中任意一个数据为基准pivot.
② 从右向左移动j,查找比pivot小的数据,找到后将j所指向的数据赋给i,D[i]=D[j]
从左向右移动i,查找比pivot大的数据,找到后将i所指向的数据赋给j.D[j]=D[i];
以此类推不断交换方向,知道i=j的时候停止.这个时候i的位置就是基准pivot所在的位置.

下面通过数据走一遍这个流程
引文用文字不好描述..所以我在本子上用笔画出来..
本人写字不好看..勿喷..^.^

php写的代码


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24


functionquick_sort(&$array,$x,$y) {

$i=$x;

$j=$y;

$key=$array[$x];//基准

while($i!=$j) {

//$j-- 查找比基准$key小的值

while($i<$j&&$array[$j] >=$key) {

$j--;

}

//  if($i < $j)

$array[$i] =$array[$j];

//$i++查找比基准$key大的值

while($i<$j&&$array[$i] <=$key) {

$i++;

}

// if($i < $j)

$array[$j] =$array[$i];

}

$array[$i] =$key;

if($x<$i-1) //左区间的数据

quick_sort($array,$x,$i-1);

if($y>$i+1)//右区间的数据

quick_sort($array,$i+1,$y);

}

  http://bbs.dzwww.com/forum.php?mod=viewthread&tid=53241034

  http://bbs.dzwww.com/forum.php?mod=viewthread&tid=53241055

  http://bbs.dzwww.com/forum.php?mod=viewthread&tid=53241072

时间: 2024-10-27 09:22:01

算法研究之快速排序的相关文章

算法研究之快速排序java版

很早之前就已经接触过快速排序算法了,面试当中也屡屡被问到,虽然明白其原理,但从未真正的用代码敲出来. 写关于算法的代码之前一定要原理想明白,不然就是盲目,在参考有关资料及自己的沉思之后,写出如下代码,中间出现了一些bug,但都很快解决了 如果有更好的优化算法,还请不吝赐教!!!! 源代码: package com.zken.test; /** * @author iamzken * 排序算法 * 使用快速排序算法对一个数组从小到大排序 * 2015-8-27 13:40 */ public cl

【算法理解】—— 快速排序 v2.0

前言 各位同学大家好,依然是随机依然是天灾- 咳咳,走错片场了. 本博文主要是叙述了本人最近研究[快速排序]算法时的一些自己的理解,因为[快速排序]算法相对于其他排序算法而言比较复杂,所以今日针对该算法进行一个总结,同时也帮助自己进一步理解该算法. 好!直接进入正题. 算法源码 由于考虑到[快速排序]算法在不同书籍上的实现方式有略微的差距,又担心手敲代码可能由于疏忽打错,所以本人双手截图以示清白. 话说上面代码的位置怎么不对呢?好吧,这是两张图,作者将两段代码分别放在两页纸中- OK,截图完毕,

基础算法之排序--快速排序

1 /************************************************************************************** 2 * Function : 快速排序 3 * Create Date : 2014/04/21 4 * Author : NTSK13 5 * Email : [email protected] 6 * Copyright : 欢迎大家和我一起交流学习,转载请保持源文件的完整性. 7 * 任何单位和个人不经本人允许不

基本算法研究1-冒泡排序算法测试

基本算法研究1-冒泡排序算法测试 1.经典冒泡排序法基本原理 先看一个动态图,感觉比较形象: 冒泡排序(Bubble Sort)是一种简单的排序算法.默认是从小到大排序,即把最大的数据排在最后,相当于每次把最大数据像气泡一样浮到水面一样.它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来.走访数列的工作是重复地进行直到没有再需要交换. 基本步骤: 1.比较相邻的元素.如果第一个比第二个大,就交换他们两个.        2.对每一对相邻元素作同样的工作,从开始第一对

HTML5游戏开发-扫雷及其算法研究

吕蒙曰:士隔三月[1],当刮目相看.所以,在下在这三月中发奋图强,花了约莫8节信息课的时间研究扫雷.呜呼,由于在下才能尚且不足,所以也就只能勉强打过中级难度的吧.不过,一边玩的同时,我还一边对扫雷这个游戏的制做方法构思了一下.所以说,本文中的算法完全是凭借自己对扫雷游戏规则的总结而自行研发出来的,倘若和MS的扫雷玩法有些出入,还望各位看官见谅. [1]出自<孙权劝学>,原文为"士别三日",由于在下这三个月来都不曾发表博客,所以引申到"士隔三月",各位看官

Supervised Descent Method Face Alignment 代码下载 和 算法研究 之一

1 主要内容: Supervised Descent Method and its Applications to Face Alignment算法研究. 2代码彩蛋:我问了好久,xxiong好心人发给我的,希望能对你们学习有帮助: 低调下载: http://humansensing.cs.cmu.edu/xxiong/mexintraface1.3.1%28release%29.zip. 注意杜绝一切商业用途,如果需要商业用途,请联系作者本人!! 3本文分为几个部分: (1)解决什么问题 (2

通用高校排课算法研究----3.基于时间片优先级排课算法

通用高校排课算法研究----3.基于时间片优先级排课算法 3   基于时间片优先级排课算法描述与分析 排课问题实质上是时间.教师.班级.教室.课程这五维关系的冲突问题,要合理的解决这个问题首先要了解排课中的一些基本原则以及排课的一些基本要求. 3.1排课中的基本原则 在课程的编排中应遵循一定的规则, 只有按照基本规则来进行课程的编排才能够减少冲突的发生, 这些基本规则主要有以下几条: 1) 同一班级的学生在同一时间(某些特定的选修课时间除外) 不能安排两门课程 2) 同一教师在同一时间不能安排两

算法——基础篇——快速排序

快速排序是一个经常使用的算法,由于每次用的时候,都感觉没有理解清楚,特写一篇文章记录一下. 算法介绍 快速排序有点类似有冒泡排序,冒泡排序从相邻的两个元素比较,小的在左边,大的在右边,这个算法很容易理解.而快速排序它相当于是在一头一尾两边分别排序比较,比较的对象是当前元素值,和一个选定的key值,主题的思想就是通过跟key值比较,把大于key的值放在右边,小于的放在左边这样就完成了一次排序,接着在对key值左边的序列进行同样的操作,右边也是,最后便能将所有的元素给排好序,由于它每次排序,都会分成

程序员面试、算法研究、编程艺术、红黑树、数据挖掘5大系列集锦

程序员面试.算法研究.编程艺术.红黑树.数据挖掘5大系列集锦