排序算法——冒泡排序

目录

一、冒泡排序的原理

二、冒泡排序的过程

三、代码实现

总结


一、冒泡排序的原理

冒泡排序是一种简单的排序算法,它通过从左往右依次遍历,比较相邻元素的大小,并根据需要交换它们的位置来排序数据,以升序为例,这个过程类似空中的泡泡,重量大的往下沉,重量小的往上浮,从而得名冒泡排序。

二、冒泡排序的过程

为了更加形象得表达这个过程,我将数组竖起来表示,首先定义一个temp作为中间变量用于交换数据,比如数组是a=[10,5,20,30,15,25],

然后判断a[0]和a[1]的关系,a[0]>a[1],由于大的要往下"沉",所以交换10和5的位置,所以引入temp来交换值。

接着再往下比较a[1]和a[2]的大小,因为 a[1]<a[2],所以不用交换,接着往下,比较a[2]和a[3]的大小,仍然不用交换,再比较a[3]和a[4]的大小,a[3]>a[4],所以交换a[3]和a[4]的值。

最后比较a[4]和a[5]的值,a[4]>a[5],继续交换两者的值

这是第一趟排序,成功把最大的30放到了最下面,然后再回到第一个单元格,进行第二趟排序......

由于每趟排序都可以排好一个位置,所以经过n-1趟就能将数组排序好,并且每趟排序之后下一趟可是少进行一次比较,因为最下面的已经被排序过了,无需再次比较。

三、代码实现

复制代码
void Bubble(int n, int* a)
{
	int temp;
	for (int i = 1; i <= n - 1; i++)
	{
		for (int j = 0; j < n - i; j++)
		{
			if (a[j] > a[j + 1])
			{
				temp = a[j];
				a[j] = a[j + 1];
				a[j + 1] = temp;
			}
		}
	}
}

总结

这种排序方法的优点是思路简单,便于理解和编写,而且是直接对数组进行操作,节省内存;缺点是循环次数较多(需要排序n-1次),运行速度较慢。可以学习,拓展思路。本节到这里了,不懂的小伙伴可以私信我。

相关推荐
董董灿是个攻城狮7 小时前
AI视觉连载8:传统 CV 之边缘检测
算法
AI软著研究员14 小时前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish14 小时前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
颜酱15 小时前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
地平线开发者1 天前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮1 天前
大模型连载2:初步认识 tokenizer 的过程
算法
地平线开发者1 天前
地平线 VP 接口工程实践(一):hbVPRoiResize 接口功能、使用约束与典型问题总结
算法·自动驾驶
罗西的思考1 天前
AI Agent框架探秘:拆解 OpenHands(10)--- Runtime
人工智能·算法·机器学习
HXhlx1 天前
CART决策树基本原理
算法·机器学习
Wect1 天前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript