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

排序算法---冒泡排序

原创不易,转载请注明出处。欢迎点赞收藏~

冒泡排序是一种简单的排序算法,其原理是重复地比较相邻的两个元素,并将顺序不正确的元素进行交换,使得每次遍历都能将一个最大(或最小)的元素放到末尾。通过多次遍历,最终实现整个序列的排序。

具体的冒泡排序算法步骤如下:

  1. 比较相邻的两个元素。如果第一个大于第二个,则交换它们的位置。
  2. 对每一对相邻元素重复步骤1,从开始到结尾。这样一次遍历之后,最大的元素会被放在序列的末尾。
  3. 针对所有的元素重复步骤1和步骤2,除了已经排好序的末尾元素。
  4. 重复步骤3,直到整个序列有序为止。

冒泡排序的时间复杂度为O(n^2),其中n为待排序序列的长度。这是因为在最坏情况下,需要进行n-1轮比较,每轮比较需要遍历剩余未排序元素。所以总共需要比较的次数为(n-1)+(n-2)+...+1=n*(n-1)/2,因此时间复杂度为O(n^2)。

冒泡排序的空间复杂度为O(1),即只需要常数级别的额外空间来存储临时交换变量,不随待排序序列的大小而变化。

冒泡排序是一种稳定的排序算法,即相等元素的相对次序在排序后保持不变。但由于其时间复杂度较高,在实际应用中较少使用,更多地作为教学和理解排序算法的基础。

C/C++语言示例如下:

#include <stdio.h>// 冒泡排序函数
void bubble_sort(int arr[], int n)
{for (int i = 0; i < n - 1; i++){for (int j = 0; j < n - i - 1; j++){if (arr[j] > arr[j + 1]){// 交换相邻元素的位置int temp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = temp;}}}
}int main()
{int arr[] = {64, 34, 25, 12, 22, 11, 90};int n = sizeof(arr) / sizeof(arr[0]);printf("排序前的数组:\n");for (int i = 0; i < n; i++){printf("%d ", arr[i]);}bubble_sort(arr, n);printf("\n排序后的数组: \n");for (int i = 0; i < n; i++){printf("%d ", arr[i]);}putchar('\n');return 0;
}

运行结果如下:

http://www.lryc.cn/news/297169.html

相关文章:

  • 基于数据挖掘的微博事件分析与可视化大屏分析系统
  • 数学建模-灰色预测最强讲义 GM(1,1)原理及Python实现
  • 智慧自助餐饮系统(SpringBoot+MP+Vue+微信小程序+JNI+ncnn+YOLOX-Nano)
  • 零基础学编程从入门到精通,系统化的编程视频教程上线,中文编程开发语言工具构件之缩放控制面板构件用法
  • 【MySQL进阶之路】MySQL 中表空间和数据区的概念以及预读机制
  • JVM 性能调优 - 常用的垃圾回收器(6)
  • 【java】Hibernate访问数据库
  • 从零开始手写mmo游戏从框架到爆炸(八)— byte数组传输
  • Elasticsearch:BM25 及 使用 Elasticsearch 和 LangChain 的自查询检索器
  • uniapp的api用法大全
  • 笔记——asp.net core 中的 REST
  • 排序算法---堆排序
  • Java字符串(包含字母和数字)通用排序
  • 【Spring】springmvc如何处理接受http请求
  • 2024年安全员-B证证模拟考试题库及安全员-B证理论考试试题
  • redis过期淘汰策略、数据过期策略与持久化方式
  • Oracle Vagrant Box 扩展根文件系统
  • TDengine用户权限管理
  • 推荐一款开源的跨平台划词翻译和OCR翻译软件:Pot
  • spring boot学习第十一篇:发邮件
  • Linux中ps/kill/execl的使用
  • 【web前端开发】HTML及CSS简单页面布局练习
  • 2.7日学习打卡----初学RabbitMQ(二)
  • 【工作学习 day04】 9. uniapp 页面和组件的生命周期
  • Mysql-数据库优化-客户端连接参数
  • 【十二】【C++】vector用法的探究
  • Docker 基本介绍
  • CentOS 7 安装 install abiword
  • 开源的直播平台
  • ChatGPT 变懒最新解释!或和系统Prompt太长有关