码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Java数据结构与Java算法学习Day02---算法排序


    目录

    一、简单排序

    1.1Comparable接口介绍 11

    1.2冒泡排序 12、13、14

    1.3选择排序 15、16、17

    1.4插入排序 18、19、20

    二、高级排序

    2.1希尔排序 21、22、23

    2.2归并排序 24

    2.2.1递归 24

    2.2.2归并排序 25

    2.3快速排序 32

    2.3.1快速排序的原理 32 

    2.3.2快速排序API设计(代码实现)33

    2.3.3快速排序的切分原理 (切分部分的原理) 34

    2.3.4快速排序切分原理部分代码实现 35

    2.3.5快速排序与归并排序的区别&&时间复杂度分析 36

    2.4排序的稳定性 37


    一、简单排序

    1.1Comparable接口介绍 11

    本部分参看ppt

    下面的三种排序仅使用于少量的数据排序情况。

    1.2冒泡排序 12、13、14

    1.3选择排序 15、16、17

    从数据中选出合适的数据,放到合适的位置。将符合要求的数据的索引和所设定位置处的索引进行交换。

    1.4插入排序 18、19、20

    相当于是倒叙的冒泡排序。

    代码部分做出解释:其余部分参看PPT。 

    最坏情况:就是后面的所有元素都需要与前面的数据进行比较与交换处理。

    二、高级排序

    2.1希尔排序 21、22、23

    希尔排序是插入排序的优化版本。

    希尔排序的原理: 

    希尔排序的思路,如下例子所示: 

    增长量h的确定:

    希尔排序代码部分的实现:

    参考PPt

    排序代码:

    外层for负责从第一个h开始处一步一步地往后移,内层for负责当前h所在组内元素的比较

    希尔排序性能判断:

    希尔排序性能不能采用事前分析法,因为涉及到数学的理解。所以采用事后分析法来对希尔排序性能进行判断。根据算法实际的跑的时间。实际测试跑试数据。

    同插入排序进行比较,性能较好。

    性能测试部分代码实现:

    2.2归并排序 24

    2.2.1递归 24

    含义:就是不断的调用自身算法

    注意:递归不能无限的自身调用,会造成栈内存溢出,需要有边界条件来约束自身调用。

    提示报错信息:

    该错误问题是:栈内存溢出异常

    2.2.2归并排序 25

    原理:

     注:归并排序主要是再归并的过程中进行排序的。

    其中最难的部分:分组后进行排序好的内容,再次合并的梳理:(参考PPT部分)28、29

     对应该部分融合部分代码实现:

    本部分的代码部分参考ppt:对下面部分的理解。

     归并排序时间复杂度分析:30、31

    注:最终归并排序的时间复杂度为O(nlogn)。比其他简单的排序性能高O(nlogn)。

     归并排序的缺点:

    2.3快速排序 32

    2.3.1快速排序的原理 32 

     快速排序:冒泡排序的升级。

    主要的点:寻找分界值

    1、寻找分界值:找排序的数据的第一个数字作为分界值。

     注:原理部分参考ppt。

    2.3.2快速排序API设计(代码实现)33

    和归并排序的设计类似。

    2.3.3快速排序的切分原理 (切分部分的原理) 34

     

    ppt切分原理如何查看:都只是移动了一步。 

    2.3.4快速排序切分原理部分代码实现 35

    参考ppt

    2.3.5快速排序与归并排序的区别&&时间复杂度分析 36

    快速排序与归并排序的区别: 

    1、快速排序不需要归并的动作。规定排序则需要。

    2、快速排序不需要等分,因为选取的第一个初始值不一行是数组的均等分的值;归并排序是进行等分的。

    时间复杂度分析:

    最优情况:

    均等分。

    最差情况:

    逆序。

    2.4排序的稳定性 37

    不稳定:冒泡排序、希尔排序、快速排序

    稳定:插入排序、归并排序

    注:

    1、一次排序的话:选择高性能排序

    2、多次排序:选择稳定排序

  • 相关阅读:
    Python学习之CSDN21天学习挑战赛计划之11
    java毕业设计藏宝阁游戏交易系统Mybatis+系统+数据库+调试部署
    UVM driver和monitor中阻塞和非阻塞
    动态分区分配算法之首次适应算法,最佳适应算法,最坏适应算法以及邻近适应算法
    Python中import os库一些函数用法
    MFC使用正则表达式基础步骤
    docker入门
    24年3月使用VS22编译Telegram Desktop
    深耕语音输入12载:讯飞输入法走向万物智能新世界
    技术应用:利用Lua脚本提升Redis操作效率与功能
  • 原文地址:https://blog.csdn.net/xiaoxixicc/article/details/128131162
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号