news 2026/4/3 3:45:42

算法 C语言 冒泡排序

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
算法 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)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/14 16:17:42

进程间通信--匿名管道

第一部分&#xff1a;通信的本质 —— “第三者”既然进程 A 和 进程 B 的内存是隔离的&#xff0c;那它们怎么交换数据&#xff1f; 答案&#xff1a;找一个它们都能看到的“第三者”。这个“第三者”通常是操作系统内核。进程 A 把数据从用户空间拷贝到内核缓冲区。进程 B 从…

作者头像 李华
网站建设 2026/4/2 16:56:07

AppleRa1n 完整指南:轻松绕过iOS激活锁的终极方案

AppleRa1n 完整指南&#xff1a;轻松绕过iOS激活锁的终极方案 【免费下载链接】applera1n icloud bypass for ios 15-16 项目地址: https://gitcode.com/gh_mirrors/ap/applera1n 还在为iPhone的激活锁问题困扰吗&#xff1f;&#x1f62b; 无论是因为忘记Apple ID密码&…

作者头像 李华
网站建设 2026/3/9 12:54:26

大数据领域数据工程的数据迁移方案

大数据领域数据工程的数据迁移方案 关键词:数据迁移、ETL、数据管道、大数据工程、数据一致性、迁移策略、数据仓库 摘要:本文深入探讨大数据领域中的数据迁移方案,从基础概念到高级策略全面解析。我们将分析数据迁移的核心挑战、主流技术架构、实施方法论,并通过实际案例展…

作者头像 李华
网站建设 2026/3/18 4:16:42

LobeChat短视频脚本创作灵感激发

LobeChat&#xff1a;让短视频创作进入“人机共写”时代 在短视频内容竞争白热化的今天&#xff0c;创作者每天都在与时间赛跑。一条爆款视频的背后&#xff0c;往往伴随着数十个被废弃的脚本、无数次深夜的头脑风暴&#xff0c;以及对“下一个创意点”的焦虑等待。有没有一种方…

作者头像 李华
网站建设 2026/4/1 17:53:06

Firefox浏览器Tampermonkey脚本实现Sketchfab模型获取技术指南

在3D设计领域&#xff0c;Sketchfab作为知名的在线模型分享平台&#xff0c;为设计师提供了丰富的资源库。然而&#xff0c;平台官方并未提供便捷的模型获取功能&#xff0c;这给需要离线使用模型的用户带来了不便。本文深入解析基于Firefox浏览器和Tampermonkey扩展的Sketchfa…

作者头像 李华