【数据结构】别跟我讲你不会冒泡排序

在这里插入图片描述

👦个人主页:Weraphael
✍🏻作者简介:目前正在学习c++和算法
✈️专栏:数据结构
🐋 希望大家多多支持,咱一起进步!😁
如果文章有啥瑕疵
希望大佬指点一二
如果文章对你有帮助的话
欢迎 评论💬 点赞👍🏻 收藏 📂 加关注😍


目录

  • 一、算法思想
  • 二、算法分析
  • 三、代码实现
  • 四、优化版思路 + 代码实现
  • 五、性能分析

一、算法思想

在这里插入图片描述

算法思想:两两相邻的元素进行比较,不满足要求则交换。

二、算法分析

为了加深对冒泡排序的理解,我们先模拟过程,以升序为例:

​​​​​​​​​​​​​​​​在这里插入图片描述

  • 第一趟排序:

第一次排序:59比较,满足升序,位置不变 5,9,3,6

第二次排序:93比较,不满足升序,位置交换,5,3,9,6

第三次排序:96比较,不满足升序,位置交换,5,3,6,9(此时9已经是最大的,无需参与排序)

因此,第一趟总共进行3次排序。

在这里插入图片描述

  • 第二趟排序:

第一次排序:53比较,不满足升序,位置交换, 3,5,6,9

第二次排序:56比较,满足升序,位置不变, 3,5,6,7(此时6已经有序,无需参与排序)

因此,第二趟总共进行2次排序。

在这里插入图片描述

  • 第三趟排序 :

第一次排序:35比较,位置不变 3,5,6,7(已经有序)

因此,第三趟总共进行1次排序。

【总结】

通过以上过程的模拟,我们可以总结以下规律

  1. 3个数进行冒泡排序,总趟数为3那么n个数进行冒泡排序,总趟数为n - 1
  2. 3个数进行冒泡排序,第一个数内部排序的次数为3,第二个数内部排序的次数为2…;那么n个数进行冒泡排序,内部的趟数应该是n - 1 - i

三、代码实现

#include <stdio.h>void Swap(int* p1, int* p2)
{int t = *p1;*p1 = *p2;*p2 = t;
}void bubble_sort(int* a, int n)
{// n个数有n - 1for (int i = 0; i < n - 1; i++){// 1个数需要排n - 1 - i次for (int j = 0; j < n - 1 - i; j++){// 两两比较,不满足条件交换if (a[j + 1] < a[j]){Swap(&a[j + 1], &a[j]);}}}
}int main()
{int a[] = { 10,1,6,9,4,7,2,3,8,5 };int aSize = sizeof(a) / sizeof(a[0]);bubble_sort(a, aSize);for (int i = 0; i < aSize; i++){printf("%d ", a[i]);}printf("\n");return 0;
}

【程序结果】

在这里插入图片描述

四、优化版思路 + 代码实现

思路:优化版是对序列进行了特判,如果某一趟遍历数组发现内部根本没有进行交换,就代表其有序

【代码实现】

这里我就不直接给出完整的代码,因为我发现有很多人搞不定边界问题,这次我就带领大家来一起分析

想搞定任何一个排序问题,首先你就必须要先写出单躺

在这里插入图片描述

假设i指向序列下标为1的位置,那我们就想i最多能到哪个地方(边界)。因为冒泡排序需要进行两两比较,那么i就一定不能等于序列长度n。因此i < n。以下就是单趟代码

void bubble_sort(int* a, int n)
{// 单趟for (int i = 1; i < n; i++){if (a[i - 1] > a[i]){Swap(&a[i - 1], &a[i]);}}
}

那接下来想:由于单趟排完之后,序列的最后一个数已经是有序的了,那么循环的判断条件就不能一直是i < n,必须要有一个变量来控制。而一开始我我们已经分析过了,n个数的冒泡排序的总趟数是n - 1

void bubble_sort(int* a, int n)
{for (int j = 0; j < n - 1; j++){for (int i = 1; i < n - j; i++){if (a[i - 1] > a[i]){Swap(&a[i - 1], &a[i]);}}}
}

最后再根据优化思路,因此优化后的完整代码 如下:

【完整代码】

#include <stdio.h>
#include <stdbool.h>void Swap(int* p1, int* p2)
{int t = *p1;*p1 = *p2;*p2 = t;
}void bubble_sort(int* a, int n)
{for (int j = 0; j < n - 1; j++){bool flag = true;for (int i = 1; i < n - j; i++){if (a[i - 1] > a[i]){Swap(&a[i - 1], &a[i]);flag = false;}}// 如果一趟排序后,没有发生交换->flag没有发生改变// 那么序列一定有序if (flag)break;}
}int main()
{int a[] = { 10,1,6,9,4,7,2,3,8,5 };int aSize = sizeof(a) / sizeof(a[0]);bubble_sort(a, aSize);for (int i = 0; i < aSize; i++){printf("%d ", a[i]);}printf("\n");return 0;
}

五、性能分析

  • 时间复杂度

① 未优化版的时间复杂度最好和最坏的情况:不管怎样每一个数都要进行两两比较,因此时间复杂度为:O(N2
② 而优化版最好的情况就是第一趟下来,没有发生交换,因此最好的时间复杂度是O(N),最坏的情况还是O(N2

综上:冒泡排序的时间复杂度是O(N2

  • 空间复杂度:O(1)
  • 稳定性:稳定

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【6】Spring Boot 3 集成组件:knift4j+springdoc+swagger3

目录 【6】Spring Boot 3 集成组件&#xff1a;knift4jspringdocswagger3OpenApi规范SpringFox Swagger3SpringFox工具&#xff08;不推荐&#xff09; Springdoc&#xff08;推荐&#xff09;从SpringFox迁移引入依赖配置jAVA Config 配置扩展配置&#xff1a;spring securit…

NumLevels

NumLevels&#xff1a;输入参数&#xff0c;最大的金字塔层数。默认auto&#xff0c;范围【0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, auto】。 AngleStart&#xff1a;输入参数&#xff0c;输入匹配时的起始角度。默认-0.39&#xff0c;建议值【 -3.14, -1.57, -0.79, -0.39, -0.20,…

CodeWhisperer 使用经验分享

今天给大家分享一下 Amazon CodeWhisperer 编程工具&#xff08;免费哦&#xff09;&#xff0c;使用这个软件后我的编码质量提升不少&#xff0c;给大家分享一下我的经验。希望大家支持哦。 Amazon CodeWhisperer 是亚⻢逊出品的一款基于机器学习的 AI 编程助手&#xff0c;可…

uniapp 实现微信小程序手机号一键登录

app 和 h5 手机号一键登录&#xff0c;参考文档&#xff1a;uni-app官网 以下是uniapp 实现微信小程序手机号一键登录 1、布局 <template><view class"mainContent"><image class"closeImg" click"onCloseClick"src"quic…

SQL学习(CTFhub)整数型注入,字符型注入,报错注入 -----手工注入+ sqlmap注入

目录 整数型注入 手工注入 为什么要将1设置为-1呢&#xff1f; sqlmap注入 sqlmap注入步骤&#xff1a; 字符型注入 手工注入 sqlmap注入 报错注入 手工注入 sqlmap注入 整数型注入 手工注入 先输入1 接着尝试2&#xff0c;3&#xff0c;2有回显&#xff0c;而3没有回显…

MySQL中外键的使用及外键约束策略

一、外键约束的概念 外键约束&#xff08;FOREIGN KEY,缩写FK是数据库设计的一个概念&#xff0c;它确保在两个表之间的关系保持数据的一致性和完整性。 外键是指表中的某个字段的依赖于另一张表中某个字段的值&#xff0c;而被依赖的字段必须具有主键约束或者唯一约束&#…

解决:java: 错误: 不支持发行版本 5 最有效方法

报错信息如图&#xff1a; 直接上终极方法&#xff1a; 修改配置文件 如图找到settings.xml文件 在标签中间插入如下代码&#xff08;jdk更改为自己电脑上的版本&#xff09; <profile><id>development</id><activation><jdk>11</jdk><…

计算机毕业设计项目选题推荐(免费领源码)java+ssm+mysql大学生本科毕业资格审核系统的设计与实现67038

摘 要 信息化社会内需要与之针对性的信息获取途径&#xff0c;但是途径的扩展基本上为人们所努力的方向&#xff0c;由于站在的角度存在偏差&#xff0c;人们经常能够获得不同类型信息&#xff0c;这也是技术最为难以攻克的课题。针对大学生本科毕业资格审核系统等问题&#…

如何优化谷歌商店里应用的评分评论1

低的评分和评论会引起的连锁反应&#xff0c;会对搜索和浏览可见性产生负面影响&#xff0c;同时拖累我们围绕应用商店优化所做的一切。所以解决负面评论的问题并提高应用的评分&#xff0c;对于提高应用商店的知名度至关重要。 1、分析应用评论。 我们需要分析应用程序当前获…

DBA_IND_STATISTICS 字段含义

功能 展示数据库中所有索引的优化器统计信息。 字段说明 参考&#xff1a;https://www.oceanbase.com/docs/enterprise-oceanbase-database-cn-10000000000885743

元数据管理,数字化时代企业的基础建设

随着新一代信息化、数字化技术的应用&#xff0c;众多领域通过科技革命和产业革命实现了深度化的数字改造&#xff0c;进入到以数据为核心驱动力的&#xff0c;全新的数据处理时代&#xff0c;并通过业务系统、商业智能BI等数字化技术和应用实现了数据价值&#xff0c;从数字经…

力扣刷题篇之数与位2

系列文章目录 目录 系列文章目录 前言 数值计算 总结 前言 本系列是个人力扣刷题汇总&#xff0c;本文是数与位。刷题顺序按照[力扣刷题攻略] Re&#xff1a;从零开始的力扣刷题生活 - 力扣&#xff08;LeetCode&#xff09; 数值计算 415. 字符串相加 - 力扣&#xff08;…

石原子科技亮相2023成都市信息领域新产品发布会

2023年11月13日至15日&#xff0c;由成都市互联网信息办公室、四川天府新区管委会、成都市经信局市新经济委、成都市农业农村局指导的以“信息创造价值 创新引领未来”为主题的成都市信息领域新产品发布会在科创生态岛1号馆举行。围绕人工智能、区块链、数字化绿色化、数字乡村…

iOS性能优化

了解屏幕成像的原理。 有一个电子枪然后在很多横轴方向上 发射电子&#xff0c;不同横轴的电子枪根据显示器中的硬件时钟产生一系列的定时信号&#xff0c;以此来让电子以不同的时间发射出去 这些电子一瞬间的运动形成了一帧动画。 CPU优化&#xff1a; 1.文本计算优化 如果一…

Unity Meta Quest 一体机开发(六):HandGrabInteractor 和 HandGrabInteractable 知识点

文章目录 &#x1f4d5;教程说明&#x1f4d5;HandGrabInteractor⭐HandGrabAPI⭐HandWristPoint⭐GripPoint⭐PinchPoint⭐PinchArea⭐HandGrabVisual⭐HandGrabGlow &#x1f4d5;HandGrabInteractable⭐Support Grab Type⭐Pinch Grab Rules 和 Palm Grab Rules⭐Unselect M…

BMS系统项目

1、通过电压监测是否冲满&#xff0c;通过电压可以监测是否放完电 电池得参数 单体过压&#xff08;充满电&#xff09; 过压恢复&#xff08;百分之90多&#xff09; 欠压保护&#xff08;百分之几得电&#xff0c;快关机了&#xff09; 欠压恢复&#xff08;就是欠压之上…

C#中.NET 6.0 Windows窗体应用通过EF访问数据库并对数据库追加、删除记录

目录 一、应用程序设计 二、应用程序源码 三、生成效果 前文作者发布了在.NET 6.0 控制台应用中通过EF访问已有数据库&#xff0c;事实上&#xff0c;在.NET 6.0 Windows窗体应用中通过EF访问已有数据库也是一样的。操作方法基本一样&#xff0c;数据库EF模型和上下文都是自…

EV代码签名证书

为了增强软件的安全性和可信度&#xff0c;EV代码签名证书&#xff08;Extended Validation Code Signing Certificate&#xff09;成为了一种具有最高级别保障的关键工具。 EV代码签名证书是一种由受信任的证书颁发机构&#xff08;CA&#xff09;或证书供应商提供的高级别代…

Harmony SDK API 版本 与 Harmony OS 版本对照表,及如何查看鸿蒙手机Harmony SDK Api 版本

Harmony SDK API 版本 与 Harmony OS 版本对照表 Harmony OSHarmony SDK APIHarmony 4.09Harmony 3.19Harmony 3.08Harmony 3.0 pre7Harmony 2.2.06Harmony 2.1.05Harmony 2.04 具体到真机上可能会有差异&#xff0c;如我的手机OS版本是2.0&#xff0c;按照上面表应该是4&…

QML20、布局

1.概述 首先,QML同样允许大家使用硬编码的方式将位置数值直接写到代码中,但是这样做首先难以适应UI的调整,其次代码维护起来也很困难。因此不推荐这样做。推荐大家使用的是以下三种布局管理器:Row,、Column、Grid、Flow,以及使用Anchor进行布局。 2.Row QML 中的 Row 元素…