备案 控制台
开发者社区 开发与运维 文章 正文

看动画学算法之:排序-快速排序

简介: 看动画学算法之:排序-快速排序

目录


  • 简介
  • 快速排序的例子
  • 快速排序的java代码实现
  • 随机快速排序的java实现
  • 快速排序的时间复杂度


简介



快速排序也采用的是分而制之的思想。那么快速排序和归并排序的区别在什么地方呢?


归并排序是将所有的元素拆分成一个个排好序的数组,然后将这些数组再进行合并。


而快速排序虽然也是拆分,但是拆分之后的操作是从数组中选出一个中间节点,然后将数组分成两部分。


左边的部分小于中间节点,右边的部分大于中间节点。


然后再分别处理左边的数组合右边的数组。


快速排序的例子



假如我们有一个数组:29,10,14,37,20,25,44,15,怎么对它进行快速排序呢?


先看一个动画:


056298.gif


我们再分析一下快速排序的步骤。


我们选择的是最左边的元素29作为中间点元素,然后将数组分成三部分:[0, 14, 15, 20, 25],[29],[44, 37]。


中间节点29已经排好序了,不需要处理。


接下来我们再对左右分别进行快速排序。最后就得到了一个所有元素都排序的数组。


快速排序的java代码实现



我们先来看最核心的部分partition,如何将数组以中间节点为界,分成左右两部分呢?


我们的最终结果,是要将array分割成为三部分。


首先我们选择最左侧的元素作为中间节点的值。然后遍历数组中的其他元素。


假如m=middleIndex,k=要遍历的元素index


考虑两种情况,第一种情况是数组中的元素比中间节点的值要大。


image.png


这种情况下,m不需要移动,k+1继续遍历即可。


第二种情况下,数组中的元素比中间节点的值要小。


image.png


因为m左边的元素都要比中间节点的值要小,所以这种情况下m需要+1,即右移一位。


现在m+1位置的元素要么还没有进行比较,要么就是比中间节点的值要大,我们可以巧妙的将m+1位置的元素和k位置的元素互换位置,这样仍然能够保证m左侧的元素要比中间节点的值要小。


将上面的分析总结成java代码如下:


private int partition(int[] array, int i, int j) {
        //选择最左侧的元素作为中心点,middleValue就是中心点的值
        int middleValue = array[i];
        int middleIndex = i;
        //从i+1遍历整个数组
        for (int k = i+1; k <= j; k++) {
            //如果数组元素小于middleValue,表示middleIndex需要右移一位
            //右移之后,我们需要将小于middleValue的array[k]移动到middleIndex的左边,
            // 最简单的办法就是交换k和middleIndex的值
            if (array[k] < middleValue) {
                middleIndex++;
                //交换数组的两个元素
                swap(array, k , middleIndex);
            } //如果数组元素大于等于middleValue,则继续向后遍历,middleIndex值不变
        }
        // 最后将中心点放入middleIndex位置
        swap(array, i, middleIndex);
        return middleIndex;
    }


最后我们需要将最左侧的元素和中间节点应该在的index的元素互换下位置,这样就将中间节点移动到了中间位置,并返回中间位置。


再来看下divide的代码:


public void doQuickSort(int[] array, int low, int high) {
        //递归的结束条件
        if (low < high) {
            //找出中心节点的值
            int middleIndex = partition(array, low, high);
            //数组分成了三部分:
            // a[low..high] ~> a[low..m–1], pivot, a[m+1..high]
            //递归遍历左侧部分
            doQuickSort(array, low, middleIndex-1);
            // a[m] 是中心节点,已经排好序了,不需要继续遍历
            //递归遍历右侧部分
            doQuickSort(array, middleIndex+1, high);
            log.info("QuickSort之后的数组:{}",array);
        }
    }


divide的代码就很简单了,找到中间节点的位置之后,我们再分别遍历数组的左右两边即可。最后得到排好序的数组。


随机快速排序的java实现



上面的例子中,我们的中间节点的选择是数组的最左元素,为了保证排序的效率,我们可以从数组中随机选择一个元素来作为中间节点。


private int partition(int[] array, int i, int j) {
        //随机选择一个元素作为中心点,middleValue就是中心点的值
        int randomIndex=i+new Random().nextInt(j-i);
        log.info("randomIndex:{}",randomIndex);
        //首先将randomIndex的值和i互换位置,就可以复用QuickSort的逻辑
        swap(array, i , randomIndex);
        int middleValue = array[i];
        int middleIndex = i;
        //从i遍历整个数组
        for (int k = i+1; k <= j; k++) {
            //如果数组元素小于middleValue,表示middleIndex需要右移一位
            //右移之后,我们需要将小于middleValue的array[k]移动到middleIndex的左边,
            // 最简单的办法就是交换k和middleIndex的值
            if (array[k] < middleValue) {
                middleIndex++;
                //交换数组的两个元素
                swap(array, k , middleIndex);
            } //如果数组元素大于等于middleValue,则继续向后遍历,middleIndex值不变
        }
        // 最后将中心点放入middleIndex位置
        swap(array, i, middleIndex);
        return middleIndex;
    }


上面的代码,我们在分区的时候,先选择出一个随机的节点,然后将这个随机的节点和最左侧的元素交换位置,后面的代码就可以重用上面的QuickSort的代码逻辑了。


快速排序的时间复杂度



从上面的分析我们可以看出,每次分区的时间复杂度应该是O(N),而divide又近似二分法,所以总的时间复杂度是O(N logN)。

flydean程序那些事
目录
相关文章
小华qvq
|
21天前
|
算法 前端开发
前端算法之快速排序
前端算法之快速排序
小华qvq
17 0
游客6z2krsj5iqmue
|
6天前
|
存储 搜索推荐 算法
快速排序算法详解
快速排序算法详解
游客6z2krsj5iqmue
17 6
什么时候能躺平
|
12天前
|
算法 C++
c++算法学习笔记 (1)快速排序
c++算法学习笔记 (1)快速排序
什么时候能躺平
17 0
微客大师
|
13天前
|
存储 搜索推荐 算法
C语言数据结构算法,常用10种排序实战
插入排序(Insertion Sort) 希尔排序(Shell Sort) 选择排序(Selection Sort) 冒泡排序(Bubble Sort) 归并排序(Merge Sort) 快速排序(Quick Sort) 堆排序(Heap Sort) 基数排序(Radix Sort)
微客大师
11 1
C语言数据结构算法,常用10种排序实战
炫酷的伊莉娜
|
15天前
|
算法 搜索推荐
【算法基础】基础算法(一)--(快速排序、归并排序、二分)
【算法基础】基础算法(一)--(快速排序、归并排序、二分)
炫酷的伊莉娜
10 0
GR鲸鱼
|
16天前
|
存储 算法 搜索推荐
数据结构与算法⑰(第五章_八大排序)(完整代码+动图+详解+对比)(下)
数据结构与算法⑰(第五章_八大排序)(完整代码+动图+详解+对比)
GR鲸鱼
21 1
GR鲸鱼
|
16天前
|
算法 编译器
数据结构与算法⑰(第五章_八大排序)(完整代码+动图+详解+对比)(中)
数据结构与算法⑰(第五章_八大排序)(完整代码+动图+详解+对比)
GR鲸鱼
35 4
GR鲸鱼
|
16天前
|
存储 算法 搜索推荐
数据结构与算法⑰(第五章_八大排序)(完整代码+动图+详解+对比)(上)
数据结构与算法⑰(第五章_八大排序)(完整代码+动图+详解+对比)
GR鲸鱼
34 6
toKeep
|
21天前
|
算法
常见的算法排序(2)
常见的算法排序(2)
toKeep
18 3
Bigcrab__
|
21天前
|
算法 搜索推荐 索引
数据结构与算法 排序(下)
数据结构与算法 排序(下)
Bigcrab__
14 1

热门文章

最新文章

  • 1
    【教程】5分钟在PAI算法市场发布自定义算法
  • 2
    AliPLC 智能丢包补偿算法,提升弱网环境的通话质量
  • 3
    想知道自己是不是精神分裂前兆,IBM的机器学习算法可以给你答案
  • 4
    “拼木头”算法挑战赛:禁忌搜索算法,用Javascript 跑
  • 5
    ML之KMeans:利用KMeans算法对Boston房价数据集(两特征+归一化)进行二聚类分析
  • 6
    算法笔试模拟题精解之“矩阵最小路径和”
  • 7
    文本比较算法Ⅵ——用线性空间计算最大公共子序列(翻译贴)
  • 8
    渠道质量评价算法概要
  • 9
    【算法导论】红黑树
  • 10
    算法学习——单链表快排
  • 1
    MVVM模型,虚拟DOM和diff算法
    199
  • 2
    Opencv(C++)学习系列---Laplacian拉普拉斯边缘检测算法
    88
  • 3
    Opencv(C++)学习系列---Canny边缘检测算法
    86
  • 4
    使用python实现FP-Growth算法
    123
  • 5
    基于yolov2深度学习网络的视频手部检测算法matlab仿真
    77
  • 6
    Python基础算法解析:支持向量机(SVM)
    103
  • 7
    探索数据结构在算法优化中的关键作用
    89
  • 8
    视觉智能平台常见问题之算法私有化部署交付给公司内部运行如何解决
    84
  • 9
    视觉智能平台常见问题之其他算法定制化开发如何解决
    85
  • 10
    使用Python实现图像处理中的边缘检测算法
    105
  • 相关课程

    更多
  • 相册服务中的故事生成算法介绍
  • Go语言核心编程 - 数据结构和算法
  • 神经网络概览及算法详解
  • 相关电子书

    更多
  • 数据+算法定义新世界
  • 袋鼠云基于实时计算的反黄牛算法
  • Alink:基于Apache Flink的算法平台
  • 相关实验场景

    更多
  • 使用Swing算法实现商品推荐
  • TLS1.3的后量子算法集成
  • RSA密码算法设计与实现
  • RSA非对称加密算法
  • 欧拉图的构造性证明与算法实现
  • 推荐系统入门之使用ALS算法实现打分预测
  • 下一篇
    2024年阿里云免费云服务器及学生云服务器申请教程参考

    深圳SEO优化公司延安企业网站建设报价巢湖建设网站报价安康网站优化推广报价乐山优化报价江门网站开发忻州网站制作设计多少钱泸州模板制作价格黄山模板推广多少钱揭阳网站推广系统推荐南通企业网站设计哪家好南平网页设计哪家好辽阳优秀网站设计公司延安网站设计模板推荐福州百度标王多少钱坪地营销型网站建设多少钱海东关键词按天计费公司蚌埠外贸网站制作多少钱晋城网站制作设计价格济南seo优化邢台百度seo公司抚州网站设计模板推荐济南网络推广价格荆州SEO按天收费多少钱长沙网站开发价格赣州设计网站莱芜网站改版多少钱黄冈企业网站制作公司海南营销型网站建设报价扬州seo网站推广公司甘孜网站推广方案多少钱歼20紧急升空逼退外机英媒称团队夜以继日筹划王妃复出草木蔓发 春山在望成都发生巨响 当地回应60岁老人炒菠菜未焯水致肾病恶化男子涉嫌走私被判11年却一天牢没坐劳斯莱斯右转逼停直行车网传落水者说“没让你救”系谣言广东通报13岁男孩性侵女童不予立案贵州小伙回应在美国卖三蹦子火了淀粉肠小王子日销售额涨超10倍有个姐真把千机伞做出来了近3万元金手镯仅含足金十克呼北高速交通事故已致14人死亡杨洋拄拐现身医院国产伟哥去年销售近13亿男子给前妻转账 现任妻子起诉要回新基金只募集到26元还是员工自购男孩疑遭霸凌 家长讨说法被踢出群充个话费竟沦为间接洗钱工具新的一天从800个哈欠开始单亲妈妈陷入热恋 14岁儿子报警#春分立蛋大挑战#中国投资客涌入日本东京买房两大学生合买彩票中奖一人不认账新加坡主帅:唯一目标击败中国队月嫂回应掌掴婴儿是在赶虫子19岁小伙救下5人后溺亡 多方发声清明节放假3天调休1天张家界的山上“长”满了韩国人?开封王婆为何火了主播靠辱骂母亲走红被批捕封号代拍被何赛飞拿着魔杖追着打阿根廷将发行1万与2万面值的纸币库克现身上海为江西彩礼“减负”的“试婚人”因自嘲式简历走红的教授更新简介殡仪馆花卉高于市场价3倍还重复用网友称在豆瓣酱里吃出老鼠头315晚会后胖东来又人满为患了网友建议重庆地铁不准乘客携带菜筐特朗普谈“凯特王妃P图照”罗斯否认插足凯特王妃婚姻青海通报栏杆断裂小学生跌落住进ICU恒大被罚41.75亿到底怎么缴湖南一县政协主席疑涉刑案被控制茶百道就改标签日期致歉王树国3次鞠躬告别西交大师生张立群任西安交通大学校长杨倩无缘巴黎奥运

    深圳SEO优化公司 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化