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

排序算法-冒泡排序(C语言实现)

简介😀

冒泡排序是一种简单但效率较低的排序算法。它重复地扫描待排序元素列表,比较相邻的两个元素,并将顺序错误的元素交换位置,直到整个列表排序完成。

实现🧐

  • 以下内容为本人原创,经过自己整理得出,有问题欢迎评论区留言,引用请标明出处,谢谢!🫡

冒泡排序

/*** @author bhlu* @date 2023-08-16* * @brief 冒泡排序* * @param[in] data 数字数组* @param[in] size 数组长度* * @return 无
*/
void bubble_sort(int data[], int size)
{// 按照上图的方法,遍历size-1次for(int i = 0; i < size - 1; i++){// 标记: 用于判断这次遍历是否了数据,0->修改,1->未修改int flag = 1;// 每轮判断的次数,按上图的方法,第一轮是size-1,然后每次都会少一次,可以使用size-1-ifor(int j = 0; j < size - 1 - i; j++){// 将索引指向的数据与索引下一个数据进行比较,大于就换位置if(data[j] > data[j+1]){int swap = data[j];data[j] = data[j+1];data[j+1] = swap;flag = 0;  // 改变标记}}if(flag)// 如果还是1,说明已经排好了,就breakbreak;}
}

完整代码🫠

  • sort.c
#include "sort.h"/*** @author bhlu* @date 2023-08-16* * @brief 冒泡排序* * @param[in] data 数字数组* @param[in] size 数组长度* * @return 无
*/
void bubble_sort(int data[], int size)
{// 按照上图的方法,遍历size-1次for(int i = 0; i < size - 1; i++){// 标记: 用于判断这次遍历是否了数据,0->修改,1->未修改int flag = 1;// 每轮判断的次数,按上图的方法,第一轮是size-1,然后每次都会少一次,可以使用size-1-ifor(int j = 0; j < size - 1 - i; j++){// 将索引指向的数据与索引下一个数据进行比较,大于就换位置if(data[j] > data[j+1]){int swap = data[j];data[j] = data[j+1];data[j+1] = swap;flag = 0;  // 改变标记}}if(flag)// 如果还是1,说明已经排好了,就breakbreak;}
}
  • sort.h
#ifndef __SORT_H
#define __SORT_H#include <stdio.h>extern void bubble_sort(int data[], int size);#endif
  • main.c
#include "sort.h"int main(void)
{int data[] = {10, 5, 2, 3, 4, 7, 6};int size = sizeof(data) / sizeof(data[0]);printf("排序前: ");for (int i = 0; i < size; i++)printf("%d ", data[i]);printf("\n");bubble_sort(data, size);printf("排序后: ");for (int i = 0; i < size; i++)printf("%d ", data[i]);printf("\n");return 0;
}
http://www.lryc.cn/news/126717.html

相关文章:

  • 星际争霸之小霸王之小蜜蜂(一)
  • 图数据库_Neo4j基于docker服务版安装_Neo4j Desktop桌面版安装---Neo4j图数据库工作笔记0004
  • docker-compose部署可道云
  • Windows上使用FFmpeg实现本地视频推送模拟海康协议rtsp视频流
  • 单片机之从C语言基础到专家编程 - 4 C语言基础 - 4.8 运算符
  • 轮腿机器人的PID控制
  • ChatGPT爆火,会给教育带来什么样的影响或者冲击?
  • Servlet+JDBC实战开发书店项目讲解第三篇:商品查询实现
  • 爬虫逆向实战(十七)--某某丁简历登录
  • 《安富莱嵌入式周报》第320期:键盘敲击声解码, 军工级boot设计,开源CNC运动控制器,C语言设计笔记,开源GPS车辆跟踪器,一键生成RTOS任务链表
  • DRF 缓存
  • Collada .dae文件格式简明教程【3D】
  • 在K8s上处理nginx
  • 嵌入式:ARM Day4
  • SpringBoot案例-员工管理-分页条件查询
  • python控制obs实现无缝切换场景!obs-websocket-py
  • Vue3实现图片懒加载及自定义懒加载指令
  • LeetCode150道面试经典题-- 环形链表(简单)
  • 音视频学习-音视频基础
  • asp.net core webapi如何执行周期性任务
  • 快速搭建图书商城小程序的简易流程与优势
  • C++ template 循环
  • 时序预测 | MATLAB实现基于CNN-BiGRU卷积双向门控循环单元的时间序列预测-递归预测未来(多指标评价)
  • mysql 数据备份和恢复
  • Lucene教程_编程入门自学教程_菜鸟教程-免费教程分享
  • 物联网工程应用实训室建设方案
  • 【AI绘画】3分钟学会ikun幻术图
  • Spring 框架入门介绍及IoC的三种注入方式
  • Centos升级openssl
  • 第4章:决策树