快速排序(概念、原理、代码)C语言

1、快速排序:,又称划分交换排序(partition-exchange sort),简称快排,一种排序算法,最早由东尼·霍尔提出。在平均状况下,排序n个项目要O(n log2 n)(大O符号)次比较。在最坏状况下则需要 O(n^2)次比较,但这种状况并不常见。事实上,快速排序 (n log n)通常明显比其他算法更快,因为它的内部循环(inner loop)可以在大部分的架构上很有效率地达成。——(维基百科)

2、快序排序:(1)是一种多次划分操作实现排序。

                        (2)每一趟选择当前所有子序列中的一个关键字(通常是第一个)作为枢轴,将子序列中比枢轴小的移到枢轴的前边, 比枢轴大的移到枢轴的后面;当本趟所有子序列都被枢轴以上述规则划分完成后会得到新的一组更短子序列,他们成为下一趟划分的初始序列集(快速排序是递归进行,需要栈的辅助,因此她需要的辅助空间比较大)

3、代码

      void QuickSort(int arr[],int low, int high){

         int temp;

         int  i=low,j=high;

         if(low<high){

                        temp=arr[low];

                        while(i<j){

                             while(i<j&&arr[j]>=temp)    --j;

                              if(i<j){

                                 arr[i]=arr[j];

                                 ++i;

                               }

                               while(i<j&&arr[i]<temp)   ++i;

                               if(i<j){

                                     arr[j]=arr[i];

                                      --j;

                                 }

                           }

                        arr[i]=temp;

                        QuickSort(arr,low,i-1);//递归对temp左边的关键字排序

                        QuickSort(arr,i+1,high);//递归对temp后边的关键字排序

                 }

   }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值