算法学习之快速排序

     快速排序是一种经常使用的排序算法,标准c里已经包含了这个算法的实现,在头文件<stdlib.h>中的qsort(),快速排序的思想是,从一个数组中挑出一个数当中枢轴,这个数的左边所有的数都比它大,右边的数都比它小,然后我们再递归的去寻找左半边和右半边,直到只剩一个数停止递归。这样全部数组就排列好了。

一次快排算法描述:1.从一个数组中挑出一个数当关键字中枢轴,一般选择第一个数

                               2.两个指针i,j一个直到数组最前方,一个最后方,i指向前边,j指向后边两个指针相向而行,我们先要从后往前遍历,如果碰到aj>key,则停止循环将aj替换ai

                               3.开始从前往后遍历,如果ai>key,则把ai替换aj

                                4.重复2和3,直到i>=j 为止

这样一次快排就完成了,保证了中枢轴左边的都小于它,右边的都大于它,但是它的左边子数组还没排好,右边也没排好,所以下面我就可以递归的定义此算法了,直到所有的都排序完成。

#include <stdio.h>
/*快速排序算法,复杂度O(nlogn)*/
void quick_sort(int *a,int from,int to)
{
    if(from >= to) //如果子数组只剩一个元素则递归完毕
        return;
    int key = a[from]; //等于数组的第一个元素
    int i = from;
    int j = to;
    while(i < j)
    {
        while(i < j && a[j] >= key) //找右边第一个比关键字小的数
            j--;
        a[i] = a[j];   //赋值到左边的一个空闲位置,这个i就是上次循环被移到后边的i,或者key所在的位置,所以不会覆盖掉
        while(i < j && a[i] <= key) //找左边第一个比关键字大的数
            i++;
        a[j] = a[i];   //复制到右边的一个空闲位置,因为这个j就是上次循环那个j的位置,所以直接覆盖
    }
    a[i] = key; //经过循环一遍后,除了key所有的数都找到了新位置,所以将key放到中枢位置
    quick_sort(a,from,i-1);//递归排序,左边子数组
    quick_sort(a,i+1,to);//递归排序右边子数组
}
int main()
{
    int n;
    int arry[100];
    scanf("%d",&n);
    int i;
    for(i = 0; i < n; i++)
        scanf("%d",&arry[i]);
    quick_sort(arry,0,n-1);
    for(i = 0; i < n; i++)
        printf("%d ",arry[i]);
    return 0;
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值