`

排序算法之快速排序

 
阅读更多

快速排序可能是应用最广泛的排序算法了。流行的原因是因为它实现简单、适用于各种不同的输入数据且在一般的应用中比其他算法都要快得多。快速排序属于原地排序,不需要额外的空间(相对于归并排序)。快速排序算法的时间复杂度为NlogN。

快速排序和归并排序类似,也是分治思想是应用。归并排序每次将数组一分为二,将两边都排序之后再合并。快速排序算法是每次将数组进行切分,保证切分点在相对于两边的子数组是有序的。左边的子数组都不大于切分点,右边的字数组都不小于切分点。

public class QuickSort extends AbstractSort implements Sort {

	@Override
	public void sort(Comparable[] a) {
		 sort(a,0,a.length - 1);
	}
	
	public void sort(Comparable[] a,int lo,int hi){
		if(hi<=lo) return;//递归结束条件
		int j = partition(a,lo,hi);
		//递归对子数组进行排序
		sort(a,lo,j-1);
		sort(a,j+1,hi);
	}

	/**
	 * 切分
	 * 使a[lo]左边元素不大于本身,右边元素不小于本身
	 */
	private int partition(Comparable[] a, int lo, int hi) {
		int i = lo,j = hi + 1;
		Comparable v = a[lo];
		while(true){
			while(less(a[++i],v)){//从左往右直到遇到一个比v大的元素
				if(i==hi) break;
			}
			while(less(v,a[--j])){//从右往左直到遇到一个比v小的元素
				if(j==lo) break;
			}
			if(i>=j){
				break;
			}
			exch(a, i, j);
		}
		exch(a, lo, j);
		return j;
	}
	public static void main(String[] args) {
		QuickSort sort = new QuickSort();
		Integer[] data = RandomFactory.randomInt(3000000, 40000);
		//sort.show(data);
		long t = System.currentTimeMillis();
		sort.sort(data);
		t = System.currentTimeMillis() - t;
		//sort.show(data);
		System.out.println("quick sort");
		System.out.println("is sorted:"+sort.isSorted(data));
		System.out.println("time consumed:" + t);
	}
}

运行结果比归并算法还稍快一点:


quick sort
is sorted:true
time consumed:1373

从排序算法代码中可以看出,算法中的切分操作发生在下一层递归之前。而归并算法的合并操作是在下一层递归之后进行的。这一点上看,快速排序有一点自上而下的味道,归并算法更类似于撒网搜网的感觉。

分享到:
评论

相关推荐

    C++排序算法之快速排序

    C++排序算法之快速排序

    python-十大排序算法之快速排序

    python python_十大排序算法之快速排序

    快速排序算法和冒泡排序效率对比

    相比之下,快速排序由C.A.R. Hoare在1960年提出,是一种分治策略的体现。快速排序的基本思想是选取一个基准值,将数组分为两部分:一部分的元素都小于基准,另一部分的元素都大于或等于基准。然后对这两部分分别进行...

    FPGA并行快速排序算法-位宽可设

    在本文中,我们将深入探讨基于FPGA的并行快速排序算法,特别关注“位宽可设”的特性。这种算法能够高效地处理大量数据,并且在硬件实现上具有很高的灵活性。我们将从以下几个方面来阐述这个主题: 一、快速排序算法...

    排序算法编程 堆排序 快速排序

    本主题将深入探讨四种常见的排序算法:堆排序、快速排序以及两种未在标题中明确提到但同样重要的排序方法——基数排序和计数排序。 首先,让我们详细了解一下堆排序。堆排序是一种基于比较的排序算法,利用了数据...

    快速排序算法相关分析

    虽然算法在最坏的情况下运行时间为 O(n^2),但由于平均运行时间为 O(nlogn),并且在内存使用、程序实现复杂性上表现优秀,尤其是对快速排序算法进行随机化的可能,使得快速排序在一般情况下是最实用的排序方法之一。...

    快速排序的并行算法

    ### 快速排序的并行算法 #### 快速排序基础概念 快速排序是一种非常高效的排序算法,由C.A.R. Hoare在1962年提出。它采用分治法的思想来对数组进行排序。具体操作是选择一个元素作为基准(pivot),然后通过一趟...

    算法设计与分析-1排序算法性能分析-冒泡/选择/插入/合并/快速排序-pre ppt

    本篇文章将详细讨论几种常见的排序算法:选择排序、冒泡排序、插入排序、合并排序以及快速排序,分析它们的算法原理、时间效率,并通过经验分析验证理论分析的准确性。 **1. 选择排序(Selection Sort)** 选择排序...

    快速排序算法以及归并算法

    根据给定的文件信息,我们将深入探讨两种经典的排序算法——快速排序和归并排序,并结合Java语言实现进行详细解析。 ### 快速排序算法 快速排序是一种高效的排序算法,采用分而治之的策略,其核心思想是选择一个...

    快速排序与归并排序的算法比较实验报告

    **快速排序与归并排序算法比较实验报告** 在计算机科学中,排序算法是处理大量数据时不可或缺的一部分。这篇实验报告将深入探讨两种经典的排序算法——快速排序和归并排序,通过对它们在Java环境中的实现和性能测试...

    快速排序算法matlab

    快速排序在平均情况下具有O(n log n)的时间复杂度,这使得它成为最常用的排序方法之一。 #### 二、快速排序算法原理 快速排序的核心在于选择一个基准值,并根据这个基准值将待排序的数据分为两部分:一部分的所有...

    随机快速排序 算法设计与分析实验报告

    快速排序算法的基本思想是:随机选取数组中的一个值,将所要进行排序的数分为左右两个部分,其中一部分的所有数据都比另外一部分的数据小,然后将所分得的两部分数据进行同样的划分,重复执行以上的划分操作,直到...

    舞动的排序算法 快速排序

    舞动的排序算法 快速排序 通过动画演示快速排序,很好的学习,课程资源。

    C++语言的算法实现包括插入排序冒泡排序堆排序快速排序

    快速排序是C++中最常用的排序算法之一,由英国计算机科学家C.A.R. Hoare提出。它使用分治策略,选择一个基准元素,将数组分为两部分,一部分的所有元素都小于基准,另一部分的元素都大于基准,然后递归地对这两部分...

    7大排序算法实现程序(快速排序,冒泡排序,选择排序,归并排序,插入排序,希尔排序,堆排序)

    本资源提供了七大经典排序算法的实现程序,包括快速排序、冒泡排序、选择排序、归并排序、插入排序、希尔排序和堆排序。下面将逐一详细介绍这些排序算法及其原理。 1. 快速排序:由C.A.R. Hoare提出,是一种采用...

    最快的排序算法 谁才是最强的排序算法:快速排序-归并排序-堆排序,排序算法数据结构

    本文将对快速排序、归并排序、堆排序等常见排序算法进行比较和分析,探讨它们的优缺点和适用场景。 首先, let's 看一下这些排序算法的时间复杂度和空间复杂度: | 排序算法 | 平均情况 | 最好情况 | 最坏情况 | ...

    8种排序算法(选择排序 冒泡排序 快速排序等~)

    这里有8种常见的排序算法,包括选择排序、冒泡排序和快速排序等。这些算法各有特点,适用于不同的场景,理解并掌握它们对于编程和数据处理至关重要。 1. **选择排序(Selection Sort)** 选择排序是一种简单直观的...

    7种常用排序算法实现(C++)(冒泡排序、选择排序、直接插入排序、希尔排序、堆排序、归并排序以及快速排序)

    这七种算法分别是:冒泡排序、选择排序、直接插入排序、希尔排序、堆排序、归并排序和快速排序。 1. **冒泡排序**: 冒泡排序是最基础的排序算法之一,通过重复遍历待排序序列,比较相邻元素并交换位置来实现排序...

    C经典算法之快速排序法(二)

    ### C经典算法之快速排序法(二) #### 知识点概述 本篇文章将深入探讨快速排序算法的一个改进版本,并通过具体的代码实现来展现这一优化思路。在快速排序法(一)的基础上,本文重点关注轴的选择对算法性能的影响...

    快速排序算法实现

    快速排序算法C语言实现,快排序算法QuickSort.cpp

Global site tag (gtag.js) - Google Analytics