快速排序算法简述

快速排序在算法具有重要的地位,每一位程序都应该了解,并且能够熟练使用,以下最简单递归实现方法(C++)

#include <iostream>
using namespace std;

void quickSort(int num[],int left,int right)
{
    int i,j,tmp;
    if(left<right)
    {
        i=left;
        j=right;
        tmp=num[left];
        while(i<j)  //填坑的方法将数据有序在相应数据的两侧
        {
            while(i<j&&num[j]>=tmp)
                j--;
            if(i<j)
                num[i++]=num[j];
            while(i<j&&num[i]<tmp)
                i++;
            if(i<j)
                num[j--]=num[i];
        }
        num[i]=tmp;
        quickSort(num,left,i-1);
        quickSort(num,i+1,right);
    }
}

int main()
{
    int i;
    int num[]={2,39,1,32,90,12};
    for(i=0;i<5;i++)
        cout<<num[i]<<',';
    cout<<num[5]<<endl;
    quickSort(num,0,5);
    for(i=0;i<5;i++)
        cout<<num[i]<<',';
    cout<<num[5]<<endl;
    return 0;
}

由于递归的特性,在数据量较大的时候并不推荐使用,但是就学习而言,递归实现是最容易理解的
上述代码中,quickSort函数 即是快速排序的核心,在Main函数中即使对排序算法的简单排序,对于代码的为何这样写,这是快排的思想,即在数组中任意取一位置,将其他的数据与它进行比较,小于的放在左边,大于或者等于的放在右边,不断这样做,当进行有限次数个后,我们便可以看到一个有序的数组,在这里,既然可取任意一位置,不妨取第一个,然后将该数两端不断进行该操作,最后即完成有序数列。

  • 需要注意的问题
    在初次看到该程序,我一直无法理解最开始的tmp值最后去哪了,这里就涉及一个常用的方法-填坑法,每一次赋值都是将后一个值代替前面一个值,这样就不需要每次都保存前面的值,只需要保存第一个开始的值,即tmp保存的num[left]
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值