C++高速排序算法

根据网上看到的高速排序算法介绍,进行的代码实现。目前的代码还是比较粗糙和繁琐的,等待后续改进~

(下面的文字介绍部分来源于https://www.cnblogs.com/yxwkf/p/3842616.html)
一、高速排序算法的基本特性
时间复杂度:O(nlgn)
最坏:O(n^2)
空间复杂度:O(n
lgn)
不稳定。

高速排序是一种排序算法,对包括n个数的输入数组,平均时间为O(nlgn),最坏情况是O(n^2)。
一般是用于排序的最佳选择。由于,基于比較的排序,最快也仅仅能达到O(nlgn)。

二、高速排序算法的描写叙述
算法导论,第7章
高速排序时基于分治模式处理的,
对一个典型子数组A[p…r]排序的分治过程为三个步骤:
1.分解:
A[p…r]被划分为俩个(可能空)的子数组A[p …q-1]和A[q+1 …r],使得
A[p …q-1] <= A[q] <= A[q+1 …r]
2.解决:通过递归调用高速排序,对子数组A[p …q-1]和A[q+1 …r]排序。
3.合并。

三、高速排序算法

版本号一:
QUICKSORT(A, p, r)
1 if p < r
2 then q ← PARTITION(A, p, r) //关键
3 QUICKSORT(A, p, q - 1)
4 QUICKSORT(A, q + 1, r)

数组划分
高速排序算法的关键是PARTITION过程,它对A[p…r]进行就地重排:
PARTITION(A, p, r)
1 x ← A[r]
2 i ← p - 1
3 for j ← p to r - 1
4 do if A[j] ≤ x
5 then i ← i + 1
6 exchange A[i] <-> A[j]
7 exchange A[i + 1] <-> A[r]
8 return i + 1

ok,咱们来举一个详细而完整的样例。
来对下面数组,进行高速排序,
2 8 7 1 3 5 6 4(主元)
在这里插入图片描述

一、

i p/j

2 8 7 1 3 5 6 4(主元)
j指的2<=4,于是i++,i也指到2,2和2互换,原数组不变。
j后移,直到指向1…
二、
j(指向1)<=4,于是i++
i指向了8,所以8与1交换。
数组变成了:
i j
2 1 7 8 3 5 6 4
三、j后移,指向了3,3<=4,于是i++
i这是指向了7,于是7与3交换。
数组变成了:
i j
2 1 3 8 7 5 6 4
四、j继续后移,发现没有再比4小的数,所以,执行到了最后一步,
即上述PARTITION(A, p, r)代码部分的 第7行。
因此,i后移一个单位,指向了8
i j
2 1 3 8 7 5 6 4
A[i + 1] <-> A[r],即8与4交换,所以,数组终于变成了例如以下形式,
2 1 3 4 7 5 6 8
ok,高速排序第一趟完毕。

4把整个数组分成了俩部分,2 1 3,7 5 6 8,再递归对这俩部分分别高速排序。
i p/j
2 1 3(主元)
2与2互换,不变,然后又是1与1互换,还是不变,最后,3与3互换,不变,
终于,3把2 1 3,分成了俩部分,2 1,和3.
再对2 1,递归排序,终于结果成为了1 2 3.

7 5 6 8(主元),7、5、6、都比8小,所以第一趟,还是7 5 6 8,
只是,此刻8把7 5 6 8,分成了 7 5 6,和8.[7 5 6->5 7 6->5 6 7]
再对7 5 6,递归排序,终于结果变成5 6 7 8。

ok,全部过程,全部分析完毕。

//quicksort
#include <iostream>   
#include <windows.h> 
#include <vector>   
#include <ctime>

using namespace std;
int times = 0;
void changeVector(vector<int>::iterator begin,vector<int>::iterator end)
{
	int num = end - begin;
	if(num <=1)
		return;
	int point = *(end - 1);
	vector<int>::iterator i, j;
	i = begin;
	j = begin;
	for(j; j != end;j++)
	{
		if(*j <= point)
		{
			int temp = *i;
			*i = *j;
			*j = temp;
			++i;
		} 
	}
	vector<int>::iterator s;
	vector<int>::iterator it = i;
	changeVector(begin,it-1);
	changeVector(it,end);

}


int main(){
	//生成随机数
	clock_t start_time = clock();
    srand(unsigned(time(NULL)));
    const int min=-100;
    const int max= 100;
    int A[100];
    for(int i=0;i<100;i++){A[i]=rand()%(max-min+1)+min;}//Generate 100 random figures
    cout<<"The random numbers are:"<<endl;
    for(int i=0;i<100;i++){cout<<A[i]<<"\t";}//Output the disordered numbers
    cout<<endl;

	vector<int>st(A,A+100);
	changeVector(st.begin(),st.end());
	cout<<endl<<endl;
	vector<int>::iterator s;
	for(s = st.begin();s != st.end();s++)
	{
		cout<<*s<<" ";
	}
	return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值