快速排序c++代码

快速排序算法通过多次比较和交换来实现排序,其排序流程如下: 

(1)首先设定一个分界值,通过该分界值将数组分成左右两部分。 

(2)将大于或等于分界值的数据集中到数组右边,小于分界值的数据集中到数组的左边。此时,左边部分中各元素都小于分界值,而右边部分中各元素都大于或等于分界值。 

(3)然后,左边和右边的数据可以独立排序。对于左侧的数组数据,又可以取一个分界值,将该部分数据分成左右两部分,同样在左边放置较小值,右边放置较大值。右侧的数组数据也可以做类似处理。 

(4)重复上述过程,通过递归将左侧部分排好序后,再递归排好右侧部分的顺序。当左、右两个部分各数据排序完成后,整个数组的排序也就完成了。

一趟快速排序的算法是: 

1)设置两个变量i、j,排序开始的时候:i=0,j=N-1; 

2)以中间数组元素作为关键数据,赋值给t,即t=a[(l+r)/2]; 

3)从i开始向后搜索,即由前开始向后搜索(i++),找到第一个大于t的值

4)从j开始向前搜索,即由后开始向前搜索(j--),找到第一个小于t的值

5)重复第3、4步,直到i==j。

代码实现如下:

#include<iostream>
using namespace std;

void quick_sort(int a[],int l,int r){
    
    //若只剩一个数则直接返回
    
    if(l>=r) return;

    //i存放左侧下标,j存放右侧下标
    //t存放分界值,这里采用数组中间的数作为分界值
    
    int i=l-1,j=r+1;
    int t=a[(l+r)/2];

    //自左向右寻找第一个比分界值大的数
    //自右向左寻找第一个比分界值小的数
    //若这两数下标不相同则交换
    //交换后若i<j,说明数组未遍历完,继续循环
    
    while (i<j)
    {
        do i++;while (a[i]<t);
        do j--;while (a[j]>t);
        if (i<j) swap(a[i],a[j]);
    }
    

    //在完成上述循环后数组会以分界值为界分为左右两部分
    //左侧都比分界值小,右侧都比分界值大
    //但是左右两侧内部并不有序,通过递归继续排序
    
    quick_sort(a,l,j);
    quick_sort(a,j+1,r);
}



int main(){
    
    int temp[100]={0};
    int num=0;
    cin>>num;

    for(int i=0; i<num; i++) cin>>temp[i];
    
    quick_sort(temp,0,num-1);

    for(int i=0; i<num; i++) cout<<temp[i]<<" ";
    
    return 0;
}

  • 4
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值