排序算法之高速排序

Posted slgkaifa

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了排序算法之高速排序相关的知识,希望对你有一定的参考价值。


这一个博客将高速排序讲的挺好的:http://blog.csdn.net/morewindows/article/details/6684558


一、算法思想描写叙述

1)令i = L,j = R,将基准数挖出形成第一个坑(基准数能够选择第一个位置上的数作为基准数,也能够选择其它位置上的数作为基准数)。

2)j--   。

从后往前扫,找到第一个比基准数小的数。并将其“挖出”,填到上一个形成的坑中arr[i]

3)i++ 。

从前往后扫,找到第一个比基准数大的数。并将其“挖出”,填到上一个形成的坑中arr[j]

4)不断地反复2)、3)直到i == j,将基准数天津最后一个坑中arr[i]


二、算法分析

技术分享


三、算法实现

/*
 * quicksort.cpp
 *
 *  Created on: 2014年5月18日
 *      Author: pc
 */


#include <iostream>
#include <cstdio>

using namespace std;

const int maxn = 10;
int arr[maxn];


void quicksort(int arr[],int l,int r){
	int i = l;
	int j = r;
	int x = arr[l];//将最左边的数作为基准数

	if(l < r){
		while(i < j){//假设i!=j就不断的进行循环

			while(i < j && arr[j] >= x){//从后往前扫,找到第一个比基准数小的数
				--j;
			}
			if(i < j){//假设找到了
				arr[i++] = arr[j];//将坑填上,并将i的值++
			}

			while(i < j && arr[i] <= x){//从前往后扫,找到第一个比基准数大的数
				++i;
			}
			if(i < j){
				arr[j--] = arr[i];//将坑填上,并将j的值--
			}
		}
		arr[i] = x;//将最后的基准位置上的坑填上

		//分治策略
		quicksort(arr,l,i-1);//递归调用
		quicksort(arr,i+1,r);
	}
}


void createReverseArr(){
	int i = 0;
	for(i = 0 ; i < maxn ; ++i){
		arr[i] = maxn - i;
	}
}

void printArr(){
	int i;
	for(i = 0 ; i < maxn ; ++i){
		printf("%d " , arr[i]);
	}
	printf("\n");
}

int main(){
	createReverseArr();
	printArr();
	quicksort(arr,0,maxn-1);
	printArr();
}
















以上是关于排序算法之高速排序的主要内容,如果未能解决你的问题,请参考以下文章

编程算法 - 高速排序算法 代码(C)

算法排序之堆排序

具体解释Redis源代码中的部分高速排序算法(pqsort.c)

算法:高速排序

经典排序之高速排序

算法学习之排序算法(高速排序)