【重温经典算法之二】快速排序

  快速排序的思想与归并排序思想类似,都是采用分治法的思想。将一个数组A[l...r]使用快速排序可以分解为三个主要的步骤:

  1. 通过随机算法获得数组A中的一个下标k,将A[k]A[r]交换。
  2. 将数组分解成左右两个数组,左边数组的值均小于A[r],右边数组的值均不小于A[r]
  3. 分别对左右两个数组进行排序,这两个数组的大小均比A小。

  通过上面的步骤,我们就可以得到快速排序的一个框架:

1 void QuickSortCore(int data[], int start, int end)
2 {
3     if (start < end)
4     {
5         int k = Partition(data, start, end);  //分解成左右两个数组
6         QuickSortCore(data, start, k - 1);  //排序左边的数组
7         QuickSortCore(data, k + 1, end);  //排序右边的数组
8     }
9 }

  从上面的代码中可以看出,分解A数组为左右两个数组是快速排序算法的关键,这个问题本质上为:对数组A中的某个值A[k]k为数组的下标),将小于A[k]的数存放在数组A的前面,将不小于A[k]的数存放在数组A的后面,分界线为x

  解决该问题的一种很直观的方法就是先将A[k]A[r]交换,然后用两个下标iji表示A[0~i]中的数都小于A[r]j0~r-1遍历数组A。如果发现A[j]小于A[r],则将A[i + 1]A[j]交换,并同时增加ij,之所以可以这样是因为A[i + 1]要么不小于A[r],要么与A[j]相同;如果A[j]不小于M,则只递增j。最后将A[i + 1]A[r]交换,i+1为左右数组的分界线x

 

 1 int Partition(int data[], int start, int end)
 2 {
 3     int k, i, j;
 4 
 5     k = GetRandom(start, end);  //通过随机函数获得数组下标
 6     Swap(data + k, data + end);  //将作为分界线的数放到最后
 7     i = start - 1;
 8     for (j = start; j < end; j++)
 9         if (data[j] < data[end])  //需要交换
10         {
11             i++;
12             Swap(data + i, data + j);
13         }
14     i++;
15     Swap(data + i, data + end);
16     return i;
17 }

 

 

  解决问题的另一个方法是先将A[k]A[l]交换,并用一个临时变量p保存A[k],也使用两个下标ij,分别初始化为lr。开始用j从数组右边遍历,知道发现A[j] < p为止,将A[j]赋值给A[i],并让i1,然后用i从数组的左边遍历,知道发现A[i] > p为止,将A[i]赋值给A[j],并让j1,然后重新开始前面的遍历,知道i == j为止。最后将p赋值给A[i],此时i为左右数组的分界线x

 

 1 int Partition(int data[], int start, int end)
 2 {
 3     int k, i, j, temp;
 4 
 5     k = GetRandom(start, end);
 6     Swap(data + k, data + start);  //将基准数放到最前面
 7     temp = data[start];  //保存基准数副本
 8     i = start;
 9     j = end;
10     while (i < j)
11     {
12        //从右边开始遍历,知道遇到小于temp的
13         while (i < j && data[j] >= temp)    
14             j--;
15         if (i < j)
16             data[i++] = data[j];
17        //从左边开始遍历,知道遇到大于temp的
18         while (i < j && data[i] <= temp)
19             i++;
20         if (i < j)
21             data[j--] = data[i];
22     }
23     data[i] = temp;
24     return i;
25 }

 

 

  前面两个方法中,第二个方法比第一个方法要好些,第二个方法用赋值替代了第一个方法中的交换。

  代码中的GetRandom函数是用来随机获得start到end之间的一个值,它可以用rand库函数实现。

 

 

转载于:https://www.cnblogs.com/chengxuyuancc/p/3546247.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/360127.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

用随机数发生器射击自己的脚

这将不是说明随机数生成器毕竟不是那么随机的文章之一。 因此&#xff0c;您中的那些人希望获得有关如何破解老虎机&#xff0c;继续前进的指南&#xff0c;在这里什么也看不到。 相反&#xff0c;它是有关一个不太常见的锁争用问题的帖子&#xff0c;该问题隐藏在Java API的随…

谈谈你对php的收获和不足,我的收获与不足

在我们的生活中&#xff0c;会经历很多不同的事情。有些是如流水般奔流向海&#xff1b;有些是如云烟一般消散&#xff1b;有些是能够像年轮般随时间流逝&#xff0c;一圈一圈留在那里&#xff0c;却始终浮现在于脑海&#xff0c;因为她曾经一次一次叮呤着你--“知不足才能自强…

cocos2dx

http://blog.csdn.net/iamlazybone/article/details/19046377 转载于:https://www.cnblogs.com/sgdkg/p/3548017.html

带有光纤的可扩展,健壮和标准的Java Web服务

这篇博客文章讨论了负载下的基准Web服务性能。 要了解有关Web服务性能理论的更多信息&#xff0c;请阅读利特尔定律&#xff0c;可伸缩性和容错 。 使用阻塞和异步IO对Web服务进行基准测试 Web应用程序&#xff08;或Web服务&#xff09;如何在负载下&#xff0c;面对各种故障…

转document.documentElement和document.body的区别

网页中获取滚动条卷去部分的高度&#xff0c;可以通过 document.body.scrollTop 来获取&#xff0c;比如使div跟着滚动条滚动&#xff1a; 转至:http://www.cnblogs.com/ckmouse/archive/2012/01/30/2332070.html <div id"div" style"width:100px;height:100…

php js 图片旋转,jQuery实现可以控制图片旋转角度效果

本文实例讲述了jQuery实现可以控制图片旋转角度效果。分享给大家供大家参考&#xff0c;具体如下&#xff1a;运行效果截图如下&#xff1a;具体代码如下&#xff1a;/p>"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">img { margin-top:100px; m…

【ARDUINO】HC-05蓝牙不配对问题

除了刷主从之外&#xff0c;不配对的原因有1&#xff1a;已经配对其他设备&#xff0c;需用ATRMAAD来移除。2、默认为蓝牙由绑定指令设置&#xff0c;需改为任意地址连接模式ATCMODE1 //#define AT 2 #define LED 12 void setup() {pinMode(LED,OUTPUT);//pinMode(AT,OUTPUT);S…

php 选股器,RSI切线突破选股指标(TDX)..

本帖最后由 yinchoo 于 2009-7-25 09:10 编辑1、对于RSI指标的运用请查坛中伟哥、井中月、cqcsshw 、九阳 等高手的贴子&#xff1a;http://www.stockwei.com/viewthread.php?tid36200&highlightRSIhttp://www.stockwei.com/viewthread.php?tid36267&highlightRSIhtt…

中等数学类杂志投稿信箱

《中国数学教育》jcme_g163.com(高中版) 《数学教学》sxjxzzmath.ecnu.edu.cn 《中学数学》hbzxsx126.com&#xff08;高中&#xff09; 《数学通讯(教师版)》shxtxjshyahoo.com.cn 《数学通讯(学生版)》shxtxxuesh163.com 《数学传播》mediamath.sinica.edu.tw 《中学教研&…

卡方检验法+matlab,【T】显著性检验(2)—卡方检验法

该博文已整理到新地址&#xff1a;记数数据统计法在各个研究领域中&#xff0c;有些研究问题只能划分为不同性质的类别&#xff0c;各类别没有量的联系。例如&#xff0c;性别分男女&#xff0c;职业分为公务员、教师、工人、……&#xff0c;教师职称又分为教授、副教授、………

【OAuth】快速入门

一、引言 1、什么是OAuth2.0&#xff1f; OAuth 2.0是一个关于授权的开放网络协议&#xff0c;允许用户授权第三方应用访问其在服务提供商上存储的资源&#xff08;如照片、视频、联系人列表&#xff09;&#xff0c;而无需将用户名和密码提供给第三方应用。OAuth 2.0在第三方应…

脚本解决.NET MVC按钮重复提交问题

见于&#xff1a;Avoiding Duplicate form submission in Asp.net MVC by clicking submit twice 脚本代码&#xff1a; $(document).on(invalid-form.validate, form, function () {var button $(this).find(input[type"submit"]);setTimeout(function () {button.…

== 与 === 介绍与区别

操作符&#xff1a; 要是两个值类型不同&#xff0c;返回false 要是两个值都是number类型&#xff0c;并且数值相同&#xff0c;返回true 要是两个值都是stirng&#xff0c;并且两个值的String内容相同&#xff0c;返回true 要是两个值都是true或者都是false&#xff0c;返回tr…

jert oracle 统计说明,Oracle JET简单入门(一)Oracle JET介绍

Oracle JET (Oracle Javascript Extension Toolkit)是一款 Oracle 的 JavaScript 拓展工具包。简单来说 Oracle JET 是一个一堆好用的前端工具结合体。Oracle JET 文档链接 http://docs.oracle.com/middleware/jet310/jet/developer/toc.htmOracle JET支持 Model-View-ViewMod…

Why you have so few friends?

Why you have so few friends?十个原因告诉你&#xff1a;为什么你的朋友那么少1. You Complain A Lot 你总是抱怨 If you’re constantly complaining about your job, lack of money, or unfair life, people won’t care to spend a lot of time with you. Complaining g…

查看oracle自动优化,使用索引查询更快,优化器为何不能自动识别

本帖最后由 〇〇 于 2015-12-24 12:17 编辑有如下查询&#xff0c;不加hint时&#xff0c;优化器自己选择的执行计划是走全表扫描&#xff0c;花费时间很长&#xff0c;但加hint强制让大表走skip index时间很短&#xff0c;根据传统的理解&#xff0c;引导列上重复出现的值越少…

javascript: 数组

var a[1,2,3] >a[0] 1 >a[1] 2 >a[2] 3 >a[3] undefined >a[-1] undefined for循环遍历每个元素 for(var key in a){console.log(a[key]);} 1 2 3 数组对象对应的方法(method) >a.length//数组元素个数 3>a.push(4)//在数组最后追加元素4>a[1, 2, 3, 4…

SELECT语句使用JDBC和Hibernate批量获取

介绍 现在&#xff0c;我已经介绍了Hibernate对INSERT &#xff0c; UPDATE和DELETE语句的批处理支持&#xff0c;是时候分析SELECT语句结果集的批量提取了。 JDBC ResultSet提供了一个客户端代理游标&#xff0c;用于获取当前语句的返回数据。 执行该语句后&#xff0c;必须将…

linux 更改父进程名称,[Linux进程]在父进程和子进程中分别修改变量

/*这是一个调用fork函数创建一个子进程&#xff0c;然后分别打印输出子进程和父进程中的变量的实例*/#include #include #include #include int glob 6; //外部变量int main(void){int var; //内部变量pid_t pid; //文件标识符var 88;//内部变量printf("…

Spring环境的搭建与测试 (spring2.5.6)

这里是采用的视频里面的spring版本 下载spring2.5.6&#xff0c; 然后进行解压缩&#xff0c;在解压目录中找到下面jar文件&#xff0c;拷贝到类路径下 dist\spring.jar lib\jakarta-commons\commons-logging.jar 上边两个是基本的jar包。。 如果使用了切面编程(AOP),还需要下列…