news 2026/7/2 7:31:13

算法 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/7/2 1:20:55

LobeChat日志聚合分析方案

LobeChat 日志聚合分析方案 在AI聊天应用日益深入企业与个人工作流的今天&#xff0c;一个看似不起眼却至关重要的问题逐渐浮出水面&#xff1a;我们真的了解用户是如何使用这些智能对话系统的吗&#xff1f; 以开源项目 LobeChat 为例&#xff0c;它凭借对多模型支持、插件扩展…

作者头像 李华
网站建设 2026/7/1 16:39:44

Java全栈开发面试实战:从基础到高阶的深度对话

Java全栈开发面试实战&#xff1a;从基础到高阶的深度对话 一、面试开场 面试官&#xff1a;你好&#xff0c;欢迎来到我们公司的面试。我是今天的面试官&#xff0c;主要负责技术评估。今天我们会围绕你的项目经验、技术能力以及对业务的理解展开讨论。你可以先简单介绍一下自…

作者头像 李华
网站建设 2026/7/2 19:15:56

安卓端秒速AI绘图:denoising-diffusion移动化实战指南

安卓端秒速AI绘图&#xff1a;denoising-diffusion移动化实战指南 【免费下载链接】denoising-diffusion-pytorch Implementation of Denoising Diffusion Probabilistic Model in Pytorch 项目地址: https://gitcode.com/gh_mirrors/de/denoising-diffusion-pytorch 还…

作者头像 李华
网站建设 2026/7/2 1:34:32

LobeChat获客成本降低方案

LobeChat&#xff1a;如何用开源技术重构企业AI获客成本模型 在今天&#xff0c;一个看似简单的用户咨询——“你们的产品支持Linux吗&#xff1f;”——背后可能藏着一场关于成本与效率的激烈博弈。传统客服需要人力响应、等待转接、查阅文档&#xff1b;而如果处理不当&#…

作者头像 李华
网站建设 2026/7/2 21:19:32

从图像到数据:WebPlotDigitizer让科研图表数字化变得如此简单

还在为论文中的精美图表无法获取原始数据而烦恼&#xff1f;面对PDF文档中的曲线图只能望图兴叹&#xff1f;科研数据恢复时因缺少关键数值而束手无策&#xff1f;WebPlotDigitizer这款革命性的开源工具&#xff0c;正在彻底改变图表数据提取的传统方式&#xff0c;让每一位研究…

作者头像 李华