1. // --------------------------------------------------------------------------------------------------------------------
  2. //
  3. //
  4. // Respect the work.
  5. //
  6. // </copyright>
  7. // <summary>
  8. //
  9. // The quick sort.
  10. //
  11. // 高速排序(QuickSort)是对冒泡排序的一种改进。它的基本思想是:通过一趟排序将要排序的数据切割成独立的两部分,当中一部分的全部数据都比另外一部分的全部数据要小,然后再按此方法对这两部分数据分别进行高速排序。整个排序过程能够递归进行,以此达到整个数据变成有序序列。
  12. //
  13. // 设要排序的数组是a[0]...a[N-1],首先随意选取一个数据(通常选用数组的首元素)作为重要数据,然后将全部比它小的数都放到它的前面,全部比它大的数都放到它的后面,这个过程称为一趟高速排序。

    值得注意的是,高速排序不是一种稳定的排序算法。也就是说,多个同样的值的相对位置或许会在算法结束时产生变动。

  14. // 一趟高速排序的算法是:
  15. // 1)设置两个变量i、j,排序開始的时候:i=0,j=N-1。
  16. // 2)以数组首元素作为重要数据,赋值给pivot,即pivot=a[0]。
  17. // 3)从j開始向前搜索,即由后開始向前搜索(j--),找到第一个小于pivot的值a[j],将a[j]赋值给a[i];
  18. // 4)从i開始向后搜索,即由前開始向后搜索(i++),找到第一个大于pivot的值a[i],将a[i]赋值给a[j];
  19. // 5)反复第3、4步,直到i==j;(在3、4步中。若没找到符合条件的值,即3中a[j]不小于pivot,4中a[i]不大于pivot的时候改变j、i的值,使得j=j-1,i=i+1,直至找到为止。

    若找到符合条件的值,进行替换的时候i、j指针位置不变。

  20. //
  21. // 高速排序的平均时间复杂度是:O(nlog<sub>2</sub>n)。
  22. //
  23. // </summary>
  24. // --------------------------------------------------------------------------------------------------------------------
  25. namespace CSharpLearning
  26. {
  27. using System;
  28. /// <summary>
  29. /// The program.
  30. /// </summary>
  31. public static class Program
  32. {
  33. /// <summary>
  34. /// The main.
  35. /// </summary>
  36. public static void Main()
  37. {
  38. int[] a = { 101, 93, 856, 7, 62, 15, 84, 3, 298, 1256 };
  39. Console.WriteLine("Before Quick Sort:");
  40. foreach (int i in a)
  41. {
  42. Console.Write(i + " ");
  43. }
  44. Console.WriteLine("\r\n");
  45. Console.WriteLine("In Quick Sort:");
  46. QuickSort(a, 0, 9);
  47. Console.WriteLine("\r\nAfter Quick Sort:");
  48. foreach (int i in a)
  49. {
  50. Console.Write(i + " ");
  51. }
  52. Console.WriteLine(string.Empty);
  53. }
  54. /// <summary>
  55. /// 高速排序。
  56. /// </summary>
  57. /// <param name="a">
  58. /// 待排序数组。
  59. /// </param>
  60. /// <param name="low">
  61. /// 待排序数组的排序起始位置。
  62. /// </param>
  63. /// <param name="high">
  64. /// 待排序数组的排序终止位置。
  65. /// </param>
  66. private static void QuickSort(int[] a, int low, int high)
  67. {
  68. if (low >= high)
  69. {
  70. return;
  71. }
  72. int pivot = QuickSortOnce(a, low, high);
  73. // 输出每一次排序。
  74. foreach (int i in a)
  75. {
  76. Console.Write(i + " ");
  77. }
  78. Console.WriteLine(string.Empty);
  79. // 对枢轴的左端进行排序。

  80. QuickSort(a, low, pivot - 1);
  81. // 对枢轴的右端进行排序。
  82. QuickSort(a, pivot + 1, high);
  83. }
  84. /// <summary>
  85. /// 一趟高速排序。

  86. /// </summary>
  87. /// <param name="a">
  88. /// 待排序数组。

  89. /// </param>
  90. /// <param name="low">
  91. /// 待排序数组的排序起始位置。
  92. /// </param>
  93. /// <param name="high">
  94. /// 待排序数组的排序终止位置。
  95. /// </param>
  96. /// <returns>
  97. /// 返回枢轴的位置。
  98. /// </returns>
  99. private static int QuickSortOnce(int[] a, int low, int high)
  100. {
  101. // 将首元素作为枢轴。
  102. int pivot = a[low];
  103. int i = low, j = high;
  104. while (i < j)
  105. {
  106. // 从右到左,寻找首个小于pivot的元素。

  107. while (a[j] >= pivot && i < j)
  108. {
  109. j--;
  110. }
  111. // 运行到此,j一定指向从右端起首个小于或等于pivot的元素。运行替换。
  112. a[i] = a[j];
  113. // 从左到右,寻找首个大于pivot的元素。

  114. while (a[i] <= pivot && i < j)
  115. {
  116. i++;
  117. }
  118. // 运行到此。i一定指向从左端起首个大于或等于pivot的元素。

    运行替换。

  119. a[j] = a[i];
  120. }
  121. // 退出while循环,运行至此,必然是i==j的情况。i(或j)指向的即是枢轴的位置,定位该趟排序的枢轴并将该位置返回。
  122. a[i] = pivot;
  123. return i;
  124. }
  125. }
  126. }
  127. // Output:
  128. /*
  129. Before Quick Sort:
  130. 101 93 856 7 62 15 84 3 298 1256
  131. In Quick Sort:
  132. 3 93 84 7 62 15 101 856 298 1256
  133. 3 93 84 7 62 15 101 856 298 1256
  134. 3 15 84 7 62 93 101 856 298 1256
  135. 3 7 15 84 62 93 101 856 298 1256
  136. 3 7 15 62 84 93 101 856 298 1256
  137. 3 7 15 62 84 93 101 298 856 1256
  138. After Quick Sort:
  139. 3 7 15 62 84 93 101 298 856 1256
  140. */

算法 quick sort的更多相关文章

  1. 快速排序算法 quick sort的理解

    最近做了一下算法的一些练习,感觉基础薄弱了,只是用一些已经有的东西来完成练习如quickSort(c++使用的时候是sort(起始位置,终止位置,比较函数),这个需要加头文件),但是不知道怎么推出来, ...

  2. 快速排序算法 Quick sort

    作者:jostree 转载请注明出处 http://www.cnblogs.com/jostree/p/4046189.html 首先随机选择一个轴,并调整数组内各个数字,使得比轴值大的数在轴的右边, ...

  3. [算法]——快速排序(Quick Sort)

    顾名思义,快速排序(quick sort)速度十分快,时间复杂度为O(nlogn).虽然从此角度讲,也有很多排序算法如归并排序.堆排序甚至希尔排序等,都能达到如此快速,但是快速排序使用更加广泛,以至于 ...

  4. 基础排序算法之快速排序(Quick Sort)

    快速排序(Quick Sort)同样是使用了分治法的思想,相比于其他的排序方法,它所用到的空间更少,因为其可以实现原地排序.同时如果随机选取中心枢(pivot),它也是一个随机算法.最重要的是,快速排 ...

  5. 经典排序算法 - 高速排序Quick sort

    经典排序算法 - 高速排序Quick sort 原理,通过一趟扫描将要排序的数据切割成独立的两部分,当中一部分的全部数据都比另外一部分的全部数据都要小,然后再按此方法对这两部分数据分别进行高速排序,整 ...

  6. Java中的经典算法之快速排序(Quick Sort)

    Java中的经典算法之快速排序(Quick Sort) 快速排序的思想 基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小, 然后再按此方法对 ...

  7. 排序算法—快速排序(Quick Sort)

    快速排序(Quick Sort) 快速排序的基本思想:通过一趟排序将待排记录分隔成独立的两部分,其中一部分记录的关键字均比另一部分的关键字小,则可分别对这两部分记录继续进行排序,以达到整个序列有序. ...

  8. 【算法】快速排序(Quick Sort)(六)

    快速排序(Quick Sort) 快速排序的基本思想:通过一趟排序将待排记录分隔成独立的两部分,其中一部分记录的关键字均比另一部分的关键字小,则可分别对这两部分记录继续进行排序,以达到整个序列有序. ...

  9. [算法] 快速排序 Quick Sort

    快速排序(Quick Sort)使用分治法策略. 它的基本思想是:选择一个基准数,通过一趟排序将要排序的数据分割成独立的两部分:其中一部分的所有数据都比另外一部分的所有数据都要小.然后,再按此方法对这 ...

随机推荐

  1. SQL OUTER JOIN

    When we want to select out all the record from two table, no matter it's present at second table or ...

  2. Java中this与super

    l  对象的this引用 作用: this关键字就是让类中一个方法,访问该类中的另一个方法或属性. 1.构造器中引用该构造器正在初始化的对象. 2.在方法中引用调用该方法的对象(哪个对象调用的方法,t ...

  3. dTree无限级文件夹树和JQuery同步Ajax请求

    曾经都是用JQuery对树的支持来实现文件夹树的,近来闲来无事就弄了下dTree,感觉其无限级文件夹还是挺好的,并且它的使用也比較方便,基本上就是先把要用的js文件即dtree.js和css文件dtr ...

  4. ActiveMQ API 详解

    4.1 开发JSM的步骤 广义上说,一个JMS 应用是几个JMS 客户端交换消息,开发JMS 客户端应用由以下几步构成:      用JNDI 得到ConnectionFactory 对象:      ...

  5. es5 - array - pop

    /** * 描述:该pop()方法从数组中删除最后一个元素并返回该元素.此方法更改数组的长度. * 语法:arr.pop() * 返回:从数组删除元素,如果为undefined则返回空该,pop方法从 ...

  6. 说说PHP中的命名空间相关概念

    说说PHP中的命名空间相关概念 1. PHP中的命名空间是什么? 什么是命名空间?"从广义上来说,命名空间是一种封装事物的方法.在非常多地方都能够见到这样的抽象概念. 比如.在操作系统中文件 ...

  7. [多校2015.02.1004 dp] hdu 5303 Delicious Apples

    题意: 在一个长度为L的环上有N棵苹果树.你的篮子容量是K个苹果. 每棵苹果树上都有a[i]个苹果. 问你从0点出发最少要走多少距离能拿完所有的苹果. 思路: 我们考虑dp,dp[0][i]代表顺时针 ...

  8. Mybatis解决字段名与实体类属性名不相同的冲突

    在平时的开发中,我们表中的字段名和表对应实体类的属性名称不一定都是完全相同的,下面来演示一下这种情况下的如何解决字段名与实体类属性名不相同的冲突. 一.准备演示需要使用的表和数据 CREATE TAB ...

  9. php 缓冲区总结

    我们先来看一段代码. <?php for ($i=10; $i>0; $i--) { echo $i; flush(); sleep(1); } ?> 按照php手册里的说法 该函数 ...

  10. Ubuntu 64编译32位程序

    首先要打开64位系统对32位的支持 第一步:确认64为架构的内核 dpkg --print-architecture 输出:adm64 说明已拥有64位架构内核. 第二步:确认打开了多架构支持功能 d ...