当前位置: 首页 > news >正文

算法 C语言 冒泡排序

目录

一、冒泡排序思想

二、冒泡排序代码

三、冒泡排序时间复杂度与空间复杂度

1. 时间复杂度分析

2. 空间复杂度分析


一、冒泡排序思想

冒泡排序的核⼼思想就是:两两相邻的元素进⾏⽐较,元素 小 / 大 就交换,然后进行下一个两两相邻的元素进⾏⽐较,重复以上动作,直到 升序 / 降序。


二、冒泡排序代码

#include<stdio.h> void bubble_sort(int* arr, int sz) { int i = 0; for (i = 0; i < sz - 1; i++) { int j = 0; int flag = 1; for (j = 0; j < sz - 1 - i; j++) { if (arr[j] > arr[j+1]) { int tmp = 0; tmp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = tmp; flag = 0; } } if (flag) { break; } } } int main() { int arr[] = { 10,9,8,7,6,5,4,3,2,1 }; int sz = sizeof(arr) / sizeof(arr[0]); bubble_sort(arr, sz); for (int i = 0; i < sz; i++) { printf("%d ", arr[i]); } return 0; }

进行升序排序,如图:


三、冒泡排序时间复杂度与空间复杂度

1. 时间复杂度分析

冒泡排序的核心操作是比较交换。我们通过嵌套循环来实现:

外层循环:控制排序的“轮数”。对于 n 个元素,最多需要 n-1 轮才能确保完全有序。

内层循环:在每一轮中,对未排序部分的相邻元素进行两两比较,并根据需要交换位置。

时间复杂度我们只讨论最坏情况:

当需要排序成升序的数组完全是逆序的时,每一轮都需要进行最大次数的比较和交换。

比较次数 =(n-1) + (n-2) + ... + 2 + 1 = n(n-1)/2

交换次数同样约为n(n-1)/2

因此,总操作次数与 n² 成正比,时间复杂度为O(n²)

2. 空间复杂度分析

冒泡排序的整个排序过程只在原数组内部进行。除了使用几个固定的临时变量(如用于交换的tmp、循环计数器i, j、判断是否已经 升序 / 降序 的flag)外,不需要申请额外的、与数据规模 n 相关的存储空间。

所以无论数组有多大,这些临时变量的数量都是固定的。因此,冒泡排序的空间复杂度为O(1)

http://www.zskr.cn/news/113230.html

相关文章:

  • uvm_sequence机制中重要task的拆解
  • LobeChat向上销售话术生成
  • PuzzleSolver:CTF MISC解题利器全面解析与实战指南
  • LobeChat优惠券系统设计:促销活动如何吸引用户?
  • 基于微信小程序的一次性环保餐具销售系统毕业设计源码(源码+lw+部署文档+讲解等)
  • 供应商管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
  • 大数据领域数据工程的数据迁移方案
  • SpringBoot+Vue 高校疫情防控web系统平台完整项目源码+SQL脚本+接口文档【Java Web毕设】
  • LobeChat插件系统全解析:打造个性化AI助手的终极武器
  • 如何用FGA自动战斗工具打造终极FGO游戏自动化体验
  • 【光子 AI 】LangGraph:Graph = 有向有环图 + 状态机实现原理详解:数据结构模型与核心算法代码实现逻辑解析
  • 16、Linux 命令使用技巧与系统资源监控指南
  • 17、Linux系统进程、文件与资源管理实用指南
  • LobeChat OpenID Connect集成
  • Ofd2Pdf完整教程:OFD转PDF的终极解决方案
  • 11、利用深度学习策略提升供应链系统中的预测性维护
  • EmotiVoice本地部署避坑指南:常见问题与解决方案
  • Windows子系统Android功能延续解决方案:在官方支持终止后的完整使用指南
  • 11、量子世界的纠缠与超决定论:从理论到实验的探索
  • 企业级工资信息管理系统管理系统源码|SpringBoot+Vue+MyBatis架构+MySQL数据库【完整版】
  • 15、Qiskit:Python 量子编程的强大 SDK
  • SpringBoot+Vue 公司资产网站管理平台源码【适合毕设/课设/学习】Java+MySQL
  • 如何让旧款Mac焕然一新:OpenCore Legacy Patcher终极使用手册
  • LobeChat支持多租户吗?SaaS化改造的技术路径
  • WorkshopDL:非Steam玩家轻松获取创意工坊模组的终极解决方案
  • AI MV 喂饭级教程
  • Godot逆向工程深度解密:资源提取技术全景剖析
  • 如何在3分钟内搭建个人专属的免费天气数据平台?Open-Meteo完整解决方案
  • 鸣潮自动化助手:解放双手的智能游戏伴侣
  • 倒计时 5 天!GOBI 2025 全球开源商业创新大会全日程发布