快速排序
来源:互联网 发布:世界顶级音乐学院知乎 编辑:程序博客网 时间:2024/06/07 11:45
简要步骤
讲排序肯定有必要讲一下快速排序,快排是因为其比较实用的分治思想,所以经常会在面试时遇到,它的基本思想是:第一步:选择基准点,通过一趟排序将准备排序的数据分为两部分,一部分比基准点都小,另一部分比基准点都大;第二步:按照第一步的方法对两个部分分别进行划分,直到数据不能被划分。
接下来,我们就通过图片来了解一下快速排序的第一步,如何将待排序数据 s[ n ]划分为两个部分:
之后对划分好的左,右两部分数据,分别利用递归方法进行分割直至不能被分割。
性能分析
时间复杂度:快速排序的平均时间复杂度为O( NlogN ),但是当数据越接近有序时,时间复杂度越接近O( N^2 ),这是因为当选择待排数据的第一个数值为基准点时,有序数据无法有效划分成左右两个部分。
空间复杂度:快速排序在每次划分数据时,都需要一个空间用来存放基准点,所以在最优情况下空间复杂度为O( logN ),在最差情况下为O( N )。
稳定性:因为相等数据会交换顺序,所以是不稳定的。
代码
#include <stdio.h>void QuickSort(int s[], int start, int end){if(s == NULL || start >= end || start < 0 || end <0)return;int i = start, j = end, x = s[start];while(i < j){while(i < j && s[j] >= x)j--;if(i < j)s[i++] = s[j];while(i < j && s[i] < x)i++;if(i < j)s[j--] = s[i];}s[i] = x;QuickSort(s, start, i-1);QuickSort(s, i+1, end);}int main(){int s[] = {4,6,3,0,2,5,1};int length = sizeof(s)/sizeof(s[0]);printf("排序前:");for(int i=0; i<length; i++){printf(" %d",s[i]);}QuickSort(s, 0, length-1);printf("\n排序后:");for(int i=0; i<length; i++){printf(" %d",s[i]);}return 0;}
阅读全文
0 0
- 快速排序
- 快速排序
- 快速排序
- 快速排序!
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- 快速排序
- c++类和类的封装,对象线程封装
- Project_Write your own operation system
- php常用处理图像函数大全
- JAVA中的异常处理机制
- Python:Python学习总结
- 快速排序
- 2017多校第二场 HDU 6040 Hints of sd0061 快速排序
- string的find和find_first_of的区别
- CODEVS 1343(伸展树)
- 使用Composer安装Laravel
- 二叉搜索树
- 大作业2(Sobel算子)
- 单片机——按键扫描
- 自定义函数实现strcpy,strcat,strcmp的功能