数据结构|排序算法(二) 冒泡排序

三、冒泡排序

1.算法思想

基本思想是:相邻两两比较,大的往后排

比较与交换:从数组的第一个元素开始,依次比较相邻的两个元素,如果前一个元素大于后一个元素,就将它们交换位置。这样,每一次比较和交换都会将当前未排序部分的最大元素 "浮" 到最后面。

多次遍历:对数组进行多次遍历,每一次遍历都会将未排序部分的最大元素放到合适的位置上,直到整个数组都被排序。

2.代码实现

复制代码
//冒泡排序
void Bubble(int* arr, int len)
{
	int tmp;
	for (int i = 0; i < len-1; i++)//len个数字需要len-1趟,最后一个数字默认有序
	{
		tmp = arr[i];
		for (int j = 0; j +1< len-i; j++)//注意越界问题;len-i提高效率
		{
			if (arr[j] > arr[j + 1])
			{
				tmp = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = tmp;
			}
		}
	}
}

3.复杂度分析

时间复杂度O(n2);空间复杂度O(1);稳定

以上是排序算法第二部分关于插入排序、希尔排序以及冒泡排序的知识,如果有帮助可以点赞收藏一下,会持续更新输出有用的内容,感兴趣可以关注我!

相关推荐
逸风尊者14 小时前
XGBoost模型工程使用
java·后端·算法
LUVK_14 小时前
第七章查找
数据结构·c++·考研·算法·408
khalil102014 小时前
代码随想录算法训练营Day-31贪心算法 | 56. 合并区间、738. 单调递增的数字、968. 监控二叉树
数据结构·c++·算法·leetcode·贪心算法·二叉树·递归
lihihi15 小时前
P9936 [NFLSPC #6] 等差数列
算法
啊我不会诶15 小时前
2024ICPC西安邀请赛补题
c++·算法
谭欣辰15 小时前
C++ 版Dijkstra 算法详解
c++·算法·图论
yuan1999715 小时前
C&CG(列与约束生成)算法,来解决“风光随机性”下的微网鲁棒配置问题
c语言·开发语言·算法
数智化精益手记局16 小时前
人员排班管理软件的自动化功能解析:解决传统手工人员进行排班管理耗时长的难题
运维·数据结构·人工智能·信息可视化·自动化·制造·精益工程
wayz1116 小时前
Day 11 编程实战:XGBoost金融预测与调参
算法·机器学习·金融·集成学习·boosting
念越16 小时前
算法每日一题 Day07|双指针求解和为S的两个数
算法·力扣