SuperHakce 算法实践之快速排序

1、算法概念。

快速排序(Quicksort)是对冒泡排序的一种改进。由C. A. R. Hoare在1962年提出。

2、算法思想。

通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。

3、实现思路。

①以第一个关键字 K 1 为控制字,将 [K 1 ,K 2 ,…,K n ] 分成两个子区,使左区所有关键字小于等于 K 1 ,右区所有关键字大于等于 K 1 ,最后控制字居两个子区中间的适当位置。在子区内数据尚处于无序状态。

②把左区作为一个整体,用①的步骤进行处理,右区进行相同的处理。(即递归)

③重复第①、②步,直到左区处理完毕。

4、源代码

package QuickSortByKey;

import java.util.Scanner;

public class QuickSortByKey {
	QuickSortByKey(){

	}
	public static void QuickSort(int [] array,int low,int top){
		if(low >= top)
			return;
		int index = array[low];
		int left = low;
		int right = top;
		while(left < right){
			while(left < right && array[right] >= index)
				right --;
			if(left < right)
				array[left ++] = array[right];
			while(left < right && array[left] <= index)
				left ++;
			if(left < right)
				array[right --] = array[left];
		}
		array[left] = index;
		QuickSort(array,low,left - 1);
		QuickSort(array,left + 1,top);
	}
	public static void main(String[] args){
		int number = 0;
		@SuppressWarnings("resource")
		Scanner scanner = new Scanner(System.in);
		number = scanner.nextInt();
		int[] map = new int[number];
		for(int i = 0;i < number;i ++){
			map[i] = scanner.nextInt();
		}
	 	QuickSort(map,0,-- number);
	 	for(int i = 0;i < number;i ++)
	 		System.out.print(map[i] + " ");
	 	System.err.println();
	}
}

5、稳定性分析

不稳定,非原址排序,因为

while(left < right){
			while(left < right && array[right] >= index)
				right --;
			if(left < right)
				array[left ++] = array[right];
			while(left < right && array[left] <= index)
				left ++;
			if(left < right)
				array[right --] = array[left];
		}

后面元素会被交换到前面等值元素的前面位置,所以快速排序是不稳定的非原址排序

时间: 2024-11-07 01:01:10

SuperHakce 算法实践之快速排序的相关文章

SuperHakce 算法实践之希尔排序

希尔排序: Shell Sort 是改进直接插入排序的一种插入排序,又叫缩小增量排序法,其选择一组逐渐缩小的增量对待排数据进行分组排序,因为其可以大跨度的交换 2 个数据,所以其算法复杂度为 O(nlogn);因为一次增量排序就是跨度为 d 的直接插入排序,所以一次增量排序是稳定的原址排序,但是整个希尔排序是不稳定的非原址排序 Shell Sort 适合 n 比较大的数据 给定实例的shell排序的排序过程 假设待排序文件有10个记录,其关键字分别是: 49,38,65,97,76,13,27,

基础算法之排序--快速排序

1 /************************************************************************************** 2 * Function : 快速排序 3 * Create Date : 2014/04/21 4 * Author : NTSK13 5 * Email : [email protected] 6 * Copyright : 欢迎大家和我一起交流学习,转载请保持源文件的完整性. 7 * 任何单位和个人不经本人允许不

算法——基础篇——快速排序

快速排序是一个经常使用的算法,由于每次用的时候,都感觉没有理解清楚,特写一篇文章记录一下. 算法介绍 快速排序有点类似有冒泡排序,冒泡排序从相邻的两个元素比较,小的在左边,大的在右边,这个算法很容易理解.而快速排序它相当于是在一头一尾两边分别排序比较,比较的对象是当前元素值,和一个选定的key值,主题的思想就是通过跟key值比较,把大于key的值放在右边,小于的放在左边这样就完成了一次排序,接着在对key值左边的序列进行同样的操作,右边也是,最后便能将所有的元素给排好序,由于它每次排序,都会分成

iOS算法(一)置快速排序算法

快速排序是当遇到较大数据时,排序快,高效的方法(公司面试时,基本上会被问到...) 该方法的基本思想是: 1.先从数列中取出一个数作为基准数. 2.分区过程,将比这个数大的数全放到它的右边,小于或等于它的数全放到它的左边. 3.再对左右区间重复第二步,直到各区间只有一个数. 简单地理解就是,找一个基准数(待排序的任意数,一般都是选定首元素),把比小于等于基准数的元素放到基准数的左边,把大于基准数的元素放在基准数的右边.排完之后,在把基准数的左边和右边各看成一个整体, 左边:继续选择基准数把小于等

[7] 算法之路 - 快速排序之3轴演算

左轴演算.中轴演算.右轴演算 题目: 快速排序法(quick sort)是目前所公认最快的排序方法之一(视解题的对象而定),虽然快速排序法在最差状况下可以达O(n2),但是在多数的情况下,快速排序法的效率表现是相当不错的. 快速排序 - 算法 1.快速排序法的基本精神是在数列中找出适当的轴心,然后将数列一分为二 2.分别对左边与右边数列进行排序 左轴演算: // 快速排序 - 左轴演算 // 1. 附设两个指针left/right,并设最左端的数为最初枢轴pivot // 2. 从右向左搜索,找

图形化排序算法比较:快速排序、插入排序、选择排序、冒泡排序

图形化排序算法比较:快速排序.插入排序.选择排序.冒泡排序

Javascript算法系列之快速排序(Quicksort)

Javascript算法系列之快速排序(Quicksort) 原文出自: http://www.nczonline.net/blog/2012/11/27/computer-science-in-javascript-quicksort/ https://gist.github.com/paullewis/1981455#file-gistfile1-js 快速排序(Quicksort)是对冒泡排序的一种改进,是一种分而治之算法归并排序的风格 核心的思想就是通过一趟排序将要排序的数据分割成独立的

算法入门之快速排序

快速排序原理: 快速排序先把等待排序的集合打乱顺序,把第一个元素作为基准元素,为第二个元素和最后一个元素分配两个指针i和j,如果a[i]小于基准元素则i++,如果a[j]大于基准元素则j--,这样把大于基准元素的a[i]和小于基准元素的a[j]互换,以此类推,最终把基准元素与a[j]相交换,就得到一个a[j]左侧全部小于a[j],右侧全部大于a[j]的一个近似有序数组,然后按照如上步骤重新寻找每个被a[j]分开的数组中的分隔点,最终得到有序数组. 在通用排序中,一般都会选取快速排序来解决问题.

算法笔记之快速排序

1.1 算法思路-- 该算法在数组中选定一个元素作为主元(一般选第一个),然后以这个主元为参考对象将数组分为两个部分,第一部分都是小于或者等于主元,第二部分都是大于或者等于主元.然后对第一和第二部分递归地使用快速排序算法,直到分到最小的小组为止. 1.2 时间复杂度-- 在最差的情况下,要把n个元素的数组划分,需要n次比较和n次移动.假设用T(n) 来表示使用快速排序算法来排序n个元素的数组所耗费的时间.那么 T(n) = T(n/2)+ T(n/2) +2n 所以,快速排序的时间复杂度应该是