算法-模拟“快速排序”
2017-03-16 13:37
316 查看
快速排序(Quicksort)是对冒泡排序的一种改进。
算法思想,
选取一个关键码key,一趟排序将要排序的数据分割成独立的两部分,key前的元素都小于key, 靠后的都大于key, 然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。
实例,无序序列如下所示,
选择6作为关键码,从后依次与9, 8, 3比较,当与3比较时,3放到6的位置,这样3的位置空余出来,
再从2开始,当比较到10时发现比6大,将10放到上次空出的位置,
再与7比较,等到空的位置时,6作为关键码的比较算完成了。
将6补于空出来的位置。
6之前的元素都小于6, 之后的都大于6。详细过程见下图,
算法实现的核心代码,
调用它
源码下载地址,
http://download.csdn.net/detail/daigualu/9783193
算法思想,
选取一个关键码key,一趟排序将要排序的数据分割成独立的两部分,key前的元素都小于key, 靠后的都大于key, 然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。
实例,无序序列如下所示,
6 2 10 7 3 8 9
选择6作为关键码,从后依次与9, 8, 3比较,当与3比较时,3放到6的位置,这样3的位置空余出来,
3 2 10 7 空 8 9
再从2开始,当比较到10时发现比6大,将10放到上次空出的位置,
3 2 空 7 10 8 9
再与7比较,等到空的位置时,6作为关键码的比较算完成了。
将6补于空出来的位置。
3 2 6 7 10 8 9
6之前的元素都小于6, 之后的都大于6。详细过程见下图,
算法实现的核心代码,
static void qsort(int[] ints,int lo,int hi) { int begin = lo; int end = hi; if (lo >= hi) return; int key = ints[lo]; while (lo < hi) { while (lo < hi && ints[hi] >= key) hi--; ints[lo] = ints[hi]; //将小的放到lo处 while (lo < hi && ints[lo] < key) lo++; ints[hi] = ints[lo];//将大的放到hi处 } ints[lo] = key; //lo和hi碰头后,这便是关键码的位置 qsort(ints, begin, lo-1); //递归,注意是lo-1 qsort(ints, lo+1, end); }
调用它
static void Main(string[] args) { int[] ints = new[] {6, 2, 10, 7, 3 ,8, 9}; qsort(ints,0,ints.Length-1); }
源码下载地址,
http://download.csdn.net/detail/daigualu/9783193
相关文章推荐
- 算法基础4:快速排序(随机化版本)
- 37定律的分析和模拟(随机数组的生成算法)
- 基础算法 快速排序
- 利用内存寻址进行快速排序的算法
- zzu 10480: 回文串 -- 模拟(最怕这种表面是算法,实际暴力的坑题)
- 第16周项目1-验证算法(4)快速排序
- C++模拟操作系统最近最少使用算法(LRU),acm
- 算法 c语言 快速排序
- 算法题(快速排序)
- 算法系列(四)排序算法中篇--归并排序和快速排序
- 数据结构与算法之模拟算法 C++实现
- 基于模拟落体碰撞的优化算法——本科毕业论文
- ’快速排序‘ (quicksort)算法的探讨(1)--- 处理大量重复数据
- 快速排序(Quicksort)算法的运算时间的全面分析
- Java模拟微信红包分配算法
- 关于负载均衡中权重分配的算法模拟
- 归并排序和快速排序比较【算法设计与分析实验报告】
- 采用伙伴系统算法编写内存分配和回收模拟程序
- 算法 排序算法之快速排序
- 数据结构实践——置换-选择算法模拟