码迷,mamicode.com
首页 > 编程语言 > 详细

排序算法之高速排序

时间:2017-05-02 10:05:45      阅读:119      评论:0      收藏:0      [点我收藏+]

标签:==   src   term   text   art   clu   tail   http   water   


这一个博客将高速排序讲的挺好的: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();
}





排序算法之高速排序

标签:==   src   term   text   art   clu   tail   http   water   

原文地址:http://www.cnblogs.com/slgkaifa/p/6794480.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!