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

C语言之冒泡排序

其实排序有很多的方法,比如:冒泡排序,插入排序,快速排序,归并排序,选择排序等。今天来讲一下最简单的排序:冒泡排序。这种排序的方法效率极其低下。

假设有一个整型数组:

int arr[10]={10,9,8,7,6,5,4,3,2,1};

一共有10个元素,下面开始比较。

10987654321

第一趟:

从第一个元素10开始,10比9大,交换;

91087654321

继续10又和8比较,交换:

98107654321

下来,10继续和7比较,又进行交换:

98710654321

........第一趟比较完后:

98765432110

才刚把10排到合适位置。

接下来,第二趟,第三趟.....一直要像第一趟那样一共执行9趟(因为有10个元素,在9趟完成之后,最后一个元素肯定已经归位,因此只需要进行九趟即可)才可以把这10个元素排好顺序。确实是效率低下啊。

好,继续看,第一趟的时候一共比较了9次。通过像上面的比较,我们可以知道,第二趟比较,需要比较8次,那么第三趟就需要7次。

因此我们用变量i来控制趟数,用变量j来控制比较次数。每比较一趟,比较次数就少一次。假设sz是数组元素的个数,那么i将从0开始,到size-1,共进行size-1趟。j变量将从0(数组首元素)开始,每比较一次,比较次数减1,因此j应该小于size-1-i。下面为参考代码:

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
void bubble_sort(int arr[],int size)
{int i = 0;int j = 0;for (i = 0; i < size - 1; i++){for (j = 0; j < size - 1 - i; j++){if (arr[j] > arr[j+1]){int temp = arr[j+1];arr[j+1] = arr[j];arr[j] = temp;}}}
}
int main()
{int i = 0;int arr[] = { 10,9,8,7,6,5,4,3,2,1};printf("排序前:>");int sz = sizeof(arr) / sizeof(arr[0]);for (i = 0; i < sz; i++){printf("%d ", arr[i]);}printf("\n");bubble_sort(arr, sz);printf("排序后:>");for (i = 0; i < sz; i++){printf("%d ", arr[i]);}return 0;
}

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

相关文章:

  • 在Linux上安装NVM(Node Version Manager)
  • 常用两种Linux命令生成器
  • 【OAuth2】授权框架的四种授权方式详解
  • AI数字人不间断直播是什么?数字人直播带货如何搭建?
  • 真菌基因组研究高分策略(二):比较基因组揭示寄主外生菌根真菌基因组的动态进化
  • uni-app之HelloWorld实现
  • CVE-2023-49898 Apache incubator-streampark 远程命令执行漏洞
  • 即将来临的2024年,汽车战场再起波澜?
  • Python 爬虫之下载视频(二)
  • 智能优化算法应用:基于原子轨道搜索算法3D无线传感器网络(WSN)覆盖优化 - 附代码
  • [机器人-2]:开源MIT Min cheetah机械狗设计(二):机械结构设计
  • 用友U8+CRM help2 任意文件读取漏洞复现
  • freeRTOS实时操作系统学习笔记
  • 解决虚拟机卡顿、卡死、待机后不动的情况(真实有效
  • 【MybatisPlus快速入门】(3)SpringBoot整合MybatisPlus 之 Lombok插件安装及MybatisPlus分页代码示例
  • SpaceDesk如何连接平板/PC(生产力副屏)
  • 61.SVN版本控制系统
  • 操作系统 内存管理篇
  • 深度学习中用来训练的train.py 探究学习2.0( 数据预处理)
  • vscode debug c++代码
  • HarmonyOS的功能及场景应用
  • 汽车级EEPROM 存储器 M24C64-DRMN3TP/K是电可擦除可编程只读存储器?它的功能特性有哪些?
  • VS Code无法远程ubuntu
  • 大数据开发职业规划
  • XxIJob入门-示例
  • 单挑力扣(LeetCode)SQL题:1549. 每件商品的最新订单(难度:中等)
  • Javacv-利用Netty实现推流直播复用(flv)
  • cfa一级考生复习经验分享系列(十一)
  • Nginx基本配置内容
  • Jenkins安装与设置(插件安装失败,版本问题解决)