排序篇(六)----排序小结(不用三连,混流量券)

排序篇(六)----排序小结

排序算法复杂度及稳定性分析

直接插入排序的算法复杂度:

  • 最好情况下,当数组已经有序时,直接插入排序的时间复杂度为O(n),其中n是数组的大小。
  • 最坏情况下,当数组逆序排列时,直接插入排序的时间复杂度为O(n^2)。
  • 平均情况下,直接插入排序的时间复杂度也为O(n^2)。

直接插入排序是一种稳定的排序算法,它的稳定性表现在相同元素的相对顺序不会改变。

希尔排序的算法复杂度:

  • 希尔排序的时间复杂度取决于增量序列的选择,最坏情况下的时间复杂度为O(n^2),平均情况下的时间复杂度为O(nlogn)。
  • 希尔排序的空间复杂度为O(1)。

希尔排序是一种不稳定的排序算法,它的不稳定性表现在相同元素的相对顺序可能会改变。

直接选择排序的算法复杂度:

  • 无论数组的初始顺序如何,直接选择排序的时间复杂度都为O(n^2)。
  • 直接选择排序的空间复杂度为O(1)。

直接选择排序是一种不稳定的排序算法,它的不稳定性表现在相同元素的相对顺序可能会改变。

堆排序的算法复杂度:

  • 堆排序的时间复杂度始终为O(nlogn),其中n是数组的大小。
  • 堆排序的空间复杂度为O(1)。

堆排序是一种不稳定的排序算法,它的不稳定性表现在相同元素的相对顺序可能会改变。

冒泡排序的算法复杂度:

  • 冒泡排序的最好情况下,当数组已经有序时,时间复杂度为O(n)。
  • 冒泡排序的最坏情况下,当数组逆序排列时,时间复杂度为O(n^2)。
  • 冒泡排序的平均情况下,时间复杂度也为O(n^2)。

冒泡排序是一种稳定的排序算法,它的稳定性表现在相同元素的相对顺序不会改变。

快速排序的算法复杂度:

  • 快速排序的最好情况下,当每次划分都能均匀地将数组分为两部分时,时间复杂度为O(nlogn)。
  • 快速排序的最坏情况下,当每次划分都选择了最大或最小的元素作为基准时,时间复杂度为O(n^2)。
  • 快速排序的平均情况下,时间复杂度为O(nlogn)。

快速排序是一种不稳定的排序算法,它的不稳定性表现在相同元素的相对顺序可能会改变。

归并排序的算法复杂度:

  • 归并排序的时间复杂度始终为O(nlogn),其中n是数组的大小。
  • 归并排序的空间复杂度为O(n)。

归并排序是一种稳定的排序算法,它的稳定性表现在相同元素的相对顺序不会改变。

计数排序的算法复杂度:

  • 计数排序的时间复杂度为O(n+k),其中n是数组的大小,k是计数数组的大小。
  • 计数排序的空间复杂度为O(n+k)。

计数排序是一种稳定的排序算法,它的稳定性表现在相同元素的相对顺序不会改变。计数排序适用于元素范围较小的情况。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

。计数排序适用于元素范围较小的情况。

[外链图片转存中…(img-N9rKGkPO-1700183881150)]

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/193515.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

解析实人认证API的工作原理与应用场景

引言 随着数字化时代的不断发展,实人认证技术在各个领域中发挥着越来越重要的作用。其中,实人认证API作为一种先进的技术手段,通过输入姓名、身份证号码和一张人脸照片,与公安库身份证头像进行权威比对,从而返回比对分…

生物神经系统的基本原理 神经元Neuron

生物神经系统的基本原理涉及一系列复杂的生物学和生理学机制,主要可以分为以下几个方面: 神经元与突触:神经系统的基本单位是神经元,它们通过突触连接彼此。神经元接收并处理来自身体其他部分或环境的信息,然后通过电信…

FFmpeg零基础学习(二)——视频文件信息获取

目录 前言正文一、获取宽高信息1、核心代码2、AVFormatContext3、avformat_alloc_context4、avformat_open_input5、avformat_find_stream_info6、av_dump_format7、av_find_best_stream End、遇到的问题1、Qt Debug模式avformat_alloc_context 无法分配对象,而Rele…

【SQL Server Management】使用手册

目录 ⛳️【SQL Server Management】 ⛳️1. 启动登录 ⛳️2. 忘记密码 ⛳️3. 操作数据库和表 3.1 新建数据库text 3.2 新建表 3.3 编辑表 3.4 编写脚本 ⛳️【SQL Server Management】 ⛳️1. 启动登录 需要开启服务 ⛳️2. 忘记密码 登录windows--> 安全性 -->…

VMware虚拟机安装华为OpenEuler欧拉系统

首先去欧拉官方网站下载openEuler的安装镜像: openEuler下载 | 欧拉系统ISO镜像 | openEuler社区官网 我下载的是最新的23.03长期维护版本,架构选择x86_64。 创建新虚拟机:选择典型配置,点击下一步:选择下载的镜像文…

如何在手机上打开电脑端本地的网页

目录 一.手机端预览VSCode生成的网页站点二.手机端预览VS2022生成的 WebApi网页站点三.总结 今天遇到了2个小问题:1.想在手机上运行VSCode上写好的网页代码。2.同样在手机上运行VS2022 WebApi生成的网页。查找了一晚上资料,终于动手解决了,记…

虽不想承认,但这就是CSGO游戏搬砖行业的现状

其实整个搬砖市场,现在已经变得乌烟瘴气,散发着“恶臭”。童话个人非常鄙视那些虚有其表,大小通吃的做法,那些甚至连搬砖数据都看不懂的人,也出来吹嘘着“实力强大,经验丰富”。这个世界太浮躁了&#xff0…

ShowWeb-浏览器插件:可视化元素路径查看器

ShowWeb👻:可视化元素路径查看器适配【谷歌】【Edge】 每次写前端最烦的就是一层一层找元素,又臭又长。所以我开发了一个小插件来缓解这个问题,这个插件可以输出整个路径,并把最后元素的内容输出方便查看,…

javascript 运算符

javascript 运算符 目录 javascript 运算符 一、算术运算符 1、自增运算符 2、自减运算符 二、比较运算符 三、赋值运算符 四、逻辑运算符 五、条件运算符 疑难解答: 这一节,我们来介绍JavaScript的运算符。运算符是完成一系列操作的符号&…

vim工具以及如何给用户加上sudo的权限

Linux开发工具之vim以及如何给用户配置sudo的权限文件的操作 1.vim概念的介绍 2.vim的多模式的介绍 3.vim的命令模式与低行模式的相关指令操作 4.vim如何配置 5.如何给普通用户配置sudo的权限 本文开始~~~~ 1. vim概念的介绍 vim是一款多模式的文本编辑器,简单…

CSGO搬砖还能做吗?CSGO饰品未来走势如何?

steam/csgo搬砖项目真能月入过万吗?到底真的假的? 如何看待CSGO饰品市场的整体走向? 从整体来说,CSGO的饰品市场与规模肯定会持续不断的上升,大盘不会发生特别大的波动,目前处于稳定期!&…

PT里如何针对某个模块设置false path

我正在「拾陆楼」和朋友们讨论有趣的话题,你⼀起来吧? 拾陆楼知识星球入口 如题,这个问题实际上讲的是get_cells的用法,我们要抓取某个模块内的全部cell,在ICC2里可以get_flat_cells xx/xx/module_name*,但…

创意二维码案例:意大利艺术家的最新二维码艺术展!

意大利艺术家——米开朗基罗皮斯特莱托(Michelangelo Pistoletto)的个人艺术展“二维码‘说’”(QR CODE POSSESSION)正在北京798艺术区的常青艺术画廊展出,这是一次别出心裁的创意艺术展! 主要体现在3个方…

final关键字-Java

final关键字 一、使用场景1、当不希望类被继承时,可以用final修饰。2、当不希望父类的某个方法被子类覆盖/重写(override)时,可以用final修饰。3、当不希望类的的某个属性的值被修改,可以用final修饰。4、当不希望某个局部变量被修改&#xf…

防火墙简介

防火墙概念 是指一种将内部网和公众访问网(如Internet)分开的方法,它实际上是一种建立在现代通信网络技术和信息安全技术基础上的应用性安全技术,隔离技术。 将需要保护的网络和不可信网络进行隔离,隐藏信息并…

振南技术干货集:znFAT 硬刚日本的 FATFS 历险记(5)

注解目录 1、znFAT 的起源 1.1 源于论坛 (那是一个论坛文化兴盛的年代。网友 DIY SDMP3 播放器激起了我的兴趣。) 1.2 硬盘 MP3 推了我一把 (“坤哥”的硬盘 MP3 播放器,让我深陷 FAT 文件系统不能自拔。) 1.3 我…

Java开发者的Python快速进修指南:自定义模块及常用模块

自定义模块 我来举一个在Java开发中常用的开发方式作为例子。在我们进行项目开发时,通常会在项目的结构中创建一个util包,用于存放一些工具类。同样,Python也可以采用类似的方式来组织代码结构,让大家更容易理解。 在同目录下 如果…

priority_queue模拟实现

目录 仿函数 模拟实现 结果 大根堆 小根堆 完整代码 priority_queue.h test.c 仿函数 仿函数的通俗定义:仿函数(functor)又称为函数对象(function object)是一个能行使函数功能 的类。仿函数的语法几乎和我们…

为啥网络安全那么缺人,但很多人却找不到工作?

文章目录 一、学校的偏向于学术二、学的东西太基础三、不上班行不行 为什么网络安全的人才缺口那么大,但是大学毕业能找到网安工作的人却很少,就连招聘都没有其他岗位多? 明明央视都说了网络安全的人才缺口还有300多万,现在找不到…

Vue框架学习笔记——计算属性

文章目录 前文提要代码需求描述插值语法实现methods实现 计算属性getter执行时间:setter 计算属性简写形式(只读不改,才能如此简写)slice截取元素,限制输入字符数量 前文提要 本人仅做个人学习记录,如有错…