一、学习要点:
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