5分钟搞定快速排序

快速排序核心思想是每趟调整基准值的位置,将小于基准值的数左移,将大于基准值的数右移,这样确保基准值左侧的数小于基准值,右侧的数大于基准值。 在下一趟时,调整上一趟分割的两个区域的基准值位置,直到最后完成所有基准值的调整。

调整基准值的前提是选择一个合理的基准值,一般是指定某个位置的数或者随机某个位置的数作为基准值( 我这里取每个区域的第一个数 ) 。

调整基准值的过程大概描述:

1、取第一个数作为基准值,声明从前往后搜索指针 i ,从后往前搜索指针 j ;

2、从后往前找,比基准值大则指针 j 减一,直到找到一个比基准值小的数,并和基准值交换(交换完后此时基准值的位置在 j );

3、从后往前查找结束再从前往后找,比基准值小则指针 i 加一,直到找到一个比基准值大的数,并和基准值交换(交换完后此时基准值的位置在 i );

4、当指针 i 等于 j 时,结束当前趟数基准值的调整。

待排序的数组如下:

image

调整基准值的过程我举个例子吧:

第一趟基准值key取72,i=0,j=8;

从后往前找,找到一个比72小的值48,与72交换,此时i=0,j=7;

image

从后往前找并交换之后确定了48是在72的左侧了,那么从前往后找的时候就不需要再判断i位置上的元素了,所以i=i+1=1。再从i的位置往后找,找到一个比72大的值88,与72交换,此时i=2,j=7;

image

从前往后找并交换之后确定了88是在72的右侧了,那么从后往前找的时候就不需要再判断j位置上的元素了,所以j=j-1=6。再从j的位置往前找,找到一个比72小的值42,与72交换,此时i=2,j=4;

image

从后往前找并交换之后确定了42是在72的左侧了,那么从前往后找的时候就不需要再判断i位置上的元素了,所以i=i+1=3。再从i的位置往后找,此时没有找到一个比72大的数,那么当前趟结束,找到基准值的位置i=j=4;

所以第一趟结束后的数组排列是:

image

查找基准值的思路大概是这样子,条理清晰之后,剩下的也就是重复上面的操作了,因此代码写起来就比较简单了。

调整基准值代码的具体实现:

image

每趟找到基准值的位置后,对基准值左边的数据和右边的数据进行基准值的调整 ,直到最后没有可调整的数据,那也就排完序了。

具体代码实现:

image

所以最后输出的数组就是排好序的数组了。

关注公众号 「吃菜长肉」,获取更多内容。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 8,722评论 0 2
  • 首先总结以下Java和C、C++中的一般控制台输入方式,方便以后的编程题: java键盘输入 java读文件(会自...
    androidjp阅读 6,798评论 0 16
  • 1.插入排序—直接插入排序(Straight Insertion Sort) 基本思想: 将一个记录插入到已排序好...
    依依玖玥阅读 5,016评论 0 2
  • 概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部...
    蚁前阅读 10,585评论 0 52
  • 高快省的排序算法 有没有既不浪费空间又可以快一点的排序算法呢?那就是“快速排序”啦!光听这个名字是不是就觉得很高端...
    博弈史密斯阅读 3,034评论 0 0