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

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

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

目录


  • 简介
  • 快速排序的例子
  • 快速排序的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程序那些事
目录
相关文章
泡沫o0
|
1月前
|
算法 调度
【软件设计师备考 专题 】算法探索:排序、查找、数值计算和字符串处理(二)
【软件设计师备考 专题 】算法探索:排序、查找、数值计算和字符串处理
泡沫o0
32 0
ForcibleBugMaker
|
16天前
|
算法 数据处理 C语言
【数据结构与算法】快速排序(详解:快排的Hoare原版,挖坑法和双指针法|避免快排最坏时间复杂度的两种解决方案|小区间优化|非递归的快排)
【数据结构与算法】快速排序(详解:快排的Hoare原版,挖坑法和双指针法|避免快排最坏时间复杂度的两种解决方案|小区间优化|非递归的快排)
ForcibleBugMaker
24 2
是阿超
|
23天前
|
搜索推荐 Java
Java基础(快速排序算法)
Java基础(快速排序算法)
是阿超
24 4
修修修也
|
26天前
|
存储 搜索推荐 算法
【数据结构】八大排序之计数排序算法
【数据结构】八大排序之计数排序算法
修修修也
11 4
修修修也
|
26天前
|
搜索推荐 算法
【数据结构】八大排序之归并排序算法
【数据结构】八大排序之归并排序算法
修修修也
20 5
修修修也
|
26天前
|
搜索推荐 算法 编译器
【数据结构】八大排序之快速排序算法
【数据结构】八大排序之快速排序算法
修修修也
35 4
吹吹晚风
|
28天前
|
算法 Python
数据结构与算法 经典排序方法(Python)
数据结构与算法 经典排序方法(Python)
吹吹晚风
24 0
快乐的流畅
|
29天前
|
存储 算法 搜索推荐
【算法】七大经典排序(插入,选择,冒泡,希尔,堆,快速,归并)(含可视化算法动图,清晰易懂,零基础入门)
【算法】七大经典排序(插入,选择,冒泡,希尔,堆,快速,归并)(含可视化算法动图,清晰易懂,零基础入门)
快乐的流畅
52 1
泡沫o0
|
1月前
|
存储 算法
【软件设计师备考 专题 】算法探索:排序、查找、数值计算和字符串处理(三)
【软件设计师备考 专题 】算法探索:排序、查找、数值计算和字符串处理
泡沫o0
27 0
泡沫o0
|
1月前
|
存储 算法 搜索推荐
【软件设计师备考 专题 】算法探索:排序、查找、数值计算和字符串处理(一)
【软件设计师备考 专题 】算法探索:排序、查找、数值计算和字符串处理
泡沫o0
108 0

热门文章

最新文章

  • 1
    【MATLAB】GA_ELM神经网络时序预测算法
  • 2
    使用Python实现DBSCAN聚类算法
  • 3
    R语言聚类算法的应用实例
  • 4
    Java数据结构与算法-java数据结构与算法(二)
  • 5
    深度思考:雪花算法snowflake分布式id生成原理详解
  • 6
    【算法】七大经典排序(插入,选择,冒泡,希尔,堆,快速,归并)(含可视化算法动图,清晰易懂,零基础入门)
  • 7
    Machine Learning机器学习之决策树算法 Decision Tree(附Python代码)
  • 8
    神经网络分类算法原理详解
  • 9
    Java数据结构与算法-java数据结构与算法(五)
  • 10
    【C/C++ 数据结构】深入探索数据结构中算法复杂度:从C++和数学的视角
  • 1
    视觉智能平台常见问题之其他算法定制化开发如何解决
    29
  • 2
    使用Python实现图像处理中的边缘检测算法
    46
  • 3
    利用机器学习算法改善电商推荐系统的效率
    75
  • 4
    Python基础算法解析:K最近邻算法
    20
  • 5
    【数据结构与算法】—— 手撕红黑树
    36
  • 6
    【优选算法】—— 字符串匹配算法
    43
  • 7
    【优选算法】—— 滑动窗口类问题
    39
  • 8
    【算法】——全排列算法讲解
    31
  • 9
    【排序算法】数据结构排序详解
    42
  • 10
    数据结构——排序算法之快速排序
    34
  • 相关课程

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

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

    更多
  • TLS1.3的后量子算法集成
  • RSA非对称加密算法
  • 下一篇
    部署LAMP环境(Alibaba Cloud Linux 3)

    深圳SEO优化公司新余关键词排名包年推广价格泰安百度网站优化公司雅安网站推广推荐江门网站定制苏州网站定制报价昌吉seo网站优化公司湘西网站设计模板公司爱联百度网站优化焦作百度网站优化排名报价大芬网站设计模板价格淮安SEO按效果付费多少钱黑河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 网站制作 网站优化