基础算法之快速排序Quick Sort

原理

快速排序(Quicksort)是对冒泡排序的一种改进。

  1. 从数列中挑出一个元素,称为"基准"(pivot);
  2. 排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面(相同的数可以到任一边)。在本次排序退出之后,该基准就处于数列的中间位置。这个称为分区(partition)操作;
  3. 递归地(recursive)把小于基准值元素的子数列和大于基准值元素的子数列排序。

例子

将无序数组[3,6,4,2,5,1]进行快速排序

1),先把第一项[3]取出来作为基准依次与其余项进行比较(3出列后大喝一声,比我小的站前边,比我大的站后边,行动吧!霸气侧漏~),

如果比[3]小就放[3]前边,2 1都比[3]小,全部放到[3]前边

如果比[3]大就放[3]后边,6 4 5比[3]大,全部放到[3]后边,

一趟排完后变成下边这样:

排序前:3,6,4,2,5,1

排序后:2,1,3,6,4,5

2),对前面一半[2,1]继续进行快速排序

重复步骤1)后变成下边这样:

排序前:2,1

排序后:1,2

前面一半排序完成,总的数组为:

排序前:2,1,3,6,4,5

排序后:1,2,3,6,4,5

3),对后面一半[6,4,5]继续进行快速排序

重复步骤1)后变成下边这样:

排序前:6,4,5

排序后:4,5,6

后面一半排序完成,总的数组为:

排序前:1,2,3,6,4,5

排序后:1,2,3,4,5,6

至此,排序结束

动画演示

代码参考

     static void Main(string[] args)
        {
            int[] intArray = { 3, 6, 4, 2, 5, 1 };
            Quick_Sort(intArray, 0, intArray.Length - 1);

            foreach (var item in intArray)
            {
                Console.WriteLine(item);
            }
            Console.ReadLine();
        }

        // 快速排序
        static void Quick_Sort(int[] unsorted, int low, int high)
        {
            int loc;
            if (low < high)
            {
                loc = partition(unsorted, low, high);
                Quick_Sort(unsorted, low, loc - 1);
                Quick_Sort(unsorted, loc + 1, high);
            }
        }

        /// <summary>
        /// 分区操作
        /// </summary>
        /// <param name="unsorted">带排序数组</param>
        /// <param name="low">起始位置</param>
        /// <param name="high">结束位置</param>
        /// <returns>排序后基准所在位置</returns>
        static int partition(int[] unsorted, int low, int high)
        {
            int pivot = unsorted[low]; // 基准
            while (low < high)
            {
                while (low < high & unsorted[high] > pivot) high--;
                unsorted[low] = unsorted[high];

                while (low < high & unsorted[low] <= pivot) low++;
                unsorted[high] = unsorted[low];
            }
            unsorted[low] = pivot;
            return low;
        }

参考资料

维基百科http://en.wikipedia.org/wiki/Quicksort

时间: 2025-01-17 08:52:56

基础算法之快速排序Quick Sort的相关文章

排序算法之快速排序(Quick Sort) -- 适用于Leetcode 75 Sort Colors

Quick Sort使用了Divide and Concur的思想: 找一个基准数, 把小于基准数的数都放到基准数之前, 把大于基准数的数都放到基准数之后 Worst case: O(n^2) Average case: O(nlogN) 步骤: 初始的数组 Array a[]: 0 1 2 3 4 5 6 7 8 9 51 73 52 18 91 7 87 73 48 3 基准数: X = a[0] = 51 i 的值: i = 0 j 的值: j = 9 (a.length) Step 1:

经典排序算法 - 快速排序Quick sort

经典排序算法 - 快速排序Quick sort 原理,通过一趟扫描将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列 举个例子 如无序数组[6 2 4 1 5 9] a),先把第一项[6]取出来, 用[6]依次与其余项进行比较, 如果比[6]小就放[6]前边,2 4 1 5都比[6]小,所以全部放到[6]前边 如果比[6]大就放[6]后边,9比[6]大,放到[6

Collection of algorithm for sorting. 常见排序算法集(三) —— Quick Sort

Quick Sort 快排,一个排序方法能直接享受这样的名称殊荣,呵呵,可见其威力与重要性. 其中最重要的思想就是 "分治"-- divide and conquer ! 这里排序用到的思想极其简单,却是很实用的!小孩子都会的简单想法. 先把所有数据分成三个部分. 在所有数据中选取某一元素X,比X小的放左边,比X大的放右边. 接着把这一思想同样分别施加在X元素的左边和右边部分,同样继续划分,选出一个元素X' 比X'小的放左边比X'大的放右边. 继续施加这种划分策略,直到划分的元素很少(

算法---快速排序(quick sort)

在前面介绍的排序算法中,最快的排序算法为归并排序,但是归并排序有一个缺陷就是排序过程中需要O(N)的额外空间.本文介绍的快速排序算法时一种原地排序算法,所需的额外空间复杂度为O(1). 算法介绍:快速排序其实一种根据需找某个元素的具体位置进行排序的方法.比如所存在如下数组 选择第一个元素5,找到5最终的位置,即5的左边的数都小于或者等于5,右边的数都大于或者等于5. 从"6"开始,可知6大于5,此处停住,从"2"开始2小于5,因此交换6与2的位置,然后接着往下走,将

排序算法 - 快速排序(Quick Sort)

算法思想 快速排序是C.R.A.Hoare于1962年提出的一种划分交换排序.它采用了一种分治的策略,通常称其为分治法(Divide-and-ConquerMethod). (1) 分治法的基本思想    分治法的基本思想是:将原问题分解为若干个规模更小但结构与原问题相似的子问题.递归地解这些子问题,然后将这些子问题的解组合为原问题的解. (2)快速排序的基本思想    设当前待排序的无序区为R[low..high],利用分治法可将快速排序的基本思想描述为:分解:      在R[low..hi

快速排序算法回顾 --冒泡排序Bubble Sort和快速排序Quick Sort(Python实现)

冒泡排序的过程是首先将第一个记录的关键字和第二个记录的关键字进行比较,若为逆序,则将两个记录交换,然后比较第二个记录和第三个记录的关键字.以此类推,直至第n-1个记录和第n个记录的关键字进行过比较为止.上述过程称为第一趟冒泡排序,接着第二趟对前面n-1个关键字进行同样操作,…… 快速排序是对冒泡排序的一种改进,通过一趟排序将记录分割成独立的两部分,其中一部分记录的关键字均比另一部分关键字小,可分别对这两部分记录以递归的方法继续进行排序,以达到整个序列有序. 单趟Partition()函数过程请看

交互设计算法基础(3) - Quick Sort

1 int pivotIndex, pivot, swapIndex; 2 3 void swap(int[] arr, int x, int y) { 4 int temp = arr[x]; 5 arr[x] = arr[y]; 6 arr[y] = temp; 7 } 8 9 void quickSort(int[] arr, int start, int end) { 10 if (end <= start) return; 11 12 pivotIndex = (start + end

java基础算法之快速排序

快速排序(Quicksort)是对冒泡排序的一种改进.在大学学过之后现在基本忘了,最近在好多地方都看到说快速排序在面试会问到,于是自己也准备重新拾起以前忘记的东西来,慢慢的积累自己的基础知识.fighting 算法概念 快速排序由C. A. R. Hoare在1962(50多年了呢)年提出,它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有

深入解析快速排序(Quick Sort)

本文将对快速排序进行深入的分析和介绍.通过学习本文,您将 秒杀快速排序面试 掌握高效实现快排 加深范型编程意识 八卦花絮 快速排序是由图灵奖获得者.计算机语言设计大佬C. A. R. Hoare在他26岁时提出的.说起C. A. R. Hoare老爷爷,可能很多人的第一印象就是快速排序,但是快排仅仅是他人生中非常小的成就而已.例如,他在1978年提出的Communicating Sequential Processes(CSP)理论,则深深的影响了并行程序设计,Go语言中的Goroutine就是