快速排序的C++实现(利用二分分治法)

一、学习要点:
1.先从数列中选取一个数作为基准数。
2.利用区分过程,为这个数确定在排序后数组的位置,区分过程为,比这个数大的数全放到他的右边,小于或等于这个数的数放到他的左边;
3.在对左右区间重复第二步,知道个区间只有一个数。
4.如果这个数组有10个数,第二步将执行十次,每次的复杂度为logn,总复杂度为O(nlogn),因为每执行一次区间排序可为数组中一个元素确定该元素在排序后的位置;
注:每走一趟的思维(挖坑填数)如下:
1.i=L;j=R;将基准数挖出形成第一个坑a[i].
2.j–由后向前找比他小的数,直到找到比他小,找到后挖出此数填前一个坑a[i]中。
3.i++由前向后找到比它大的数,找到后也挖出此数填到前一个坑a[j]中。
4.在重复执行2、3两步,直到i==j,将基准数填入a[i]中。
二、实现代码:

#include<iostream>
using namespace std;
//函数声明
void quicksort(int a[],int l,int r);
int main(){

return 0;
}
//函数的定义
void quicksort(int a[],int l,int r){
//递归体	
	if(l<r){
		int i=l,j=r,x=a[l];
		while(i<j){
		while(i<j&a[j]>x){
			j--;
		}
		if(i<j){
			a[i++]=a[j];
		}
		while(i<j&a[i]<x){
			i++;
		}
		if(i<j){
			a[j--]=a[i]
		}
		}
		a[i]=x;//每次走一趟确定一个;
		quicksort(a,l,i-1);
		quicksort(a,i+1,r);
	}
//递归头
//l=r
}

三、程序运行结果图:
在这里插入图片描述
四、注意事项:
1.每次走完一趟后要确定一个元素在排序后数组中的位置;
2.利用填坑的思维而不是数组元素的交换(在每走一趟的过程中)
喜欢请点赞 谢谢


具体matlab代码参考:https://download.csdn.net/download/fyf18845165207/10886708

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值