八大排序之冒泡排序+选择排序

先给一个数组arr[]{5,2,9,1,5,6}通过这个数组讲解

一、冒泡排序(从小到大)

原理:相邻两个数比较,大的往后 "冒",每一趟确定最后一个最大数

数组:5 2 9 1 5 6一共 6 个数,需要 5 趟

第 1 趟(确定最后一位:最大数 9)

从头两两比:

  • 5 和 2 → 5>2,交换 → 2 5 9 1 5 6
  • 5 和 9 → 不换
  • 9 和 1 → 9>1,交换 → 2 5 1 9 5 6
  • 9 和 5 → 9>5,交换 → 2 5 1 5 9 6
  • 9 和 6 → 9>6,交换 → 2 5 1 5 6 9

第 1 趟结束:2 5 1 5 6 9

第 2 趟(确定倒数第二位:6)

只比前 5 个:2 5 1 5 6

  • 2 和 5 → 不换
  • 5 和 1 → 交换 → 2 1 5 5 6
  • 5 和 5 → 不换
  • 5 和 6 → 不换

第 2 趟结束:2 1 5 5 6 9

第 3 趟(确定倒数第三位:5)

只比前 4 个:2 1 5 5

  • 2 和 1 → 交换 → 1 2 5 5
  • 2 和 5 → 不换
  • 5 和 5 → 不换

第 3 趟结束:1 2 5 5 6 9

第 4 趟

比前 3 个:1 2 5已经有序,无交换。结果不变:1 2 5 5 6 9

第 5 趟

比前 2 个:1 2有序,无交换。

最终排序:1 2 5 5 6 9

代码实现:

cpp 复制代码
void BubbleSort1(int* arr, int len)
{
	for (int i = 0; i < len - 1; i++)
	{
		for (int j = 0; j < len - 1 - i; j++)
		{
			if (arr[j] > arr[j + 1])
			{
				swap(arr[j], arr[j + 1]);
			}
		}
	}
}

冒泡优化:给一个tag 当一趟下来没有交换的时候,说明这时候的数组已经有序了,则直接return

cpp 复制代码
void BubbleSort2(int* arr, int len)
{
	
	for (int i = 0; i < len - 1; i++)
	{
		bool tag = true;
		for (int j = 0; j < len - 1 - i; j++)
		{
			if (arr[j] > arr[j + 1])
			{
				swap(arr[j], arr[j + 1]);
				tag = false;
			}
			
		}
		if (tag)return;
	}
}

二、选择排序(从小到大)

原理:每一趟在未排序部分找最小值,直接和未排序第一个位置交换。

数组:5 2 9 1 5 6同样 5 趟。

第 1 趟(确定第 1 位)

未排序:5 2 9 1 5 6找最小值:1(下标 3)和第 1 位交换:

第 1 趟结束:1 2 9 5 5 6

第 2 趟(确定第 2 位)

未排序从第 2 位开始:2 9 5 5 6最小值是 2,已经在位置上,不用交换。

第 2 趟结束:1 2 9 5 5 6

第 3 趟(确定第 3 位)

未排序从第 3 位开始:9 5 5 6最小值是 5(下标 3)和第 3 位交换:

第 3 趟结束:1 2 5 9 5 6

第 4 趟(确定第 4 位)

未排序从第 4 位开始:9 5 6最小值是 5(下标 4)和第 4 位交换:

第 4 趟结束:1 2 5 5 9 6

第 5 趟(确定第 5 位)

未排序从第 5 位开始:9 6最小值是 6(下标 5)和第 5 位交换:

第 5 趟结束:1 2 5 5 6 9

cpp 复制代码
void SelectSort(int* arr, int len)
{
	if (arr == nullptr || len <= 0) return;
	for (int i = 0; i < len - 1; i++)
	{
		int Index = i;
		for (int j = i + 1; j < len; j++)
		{
			if (arr[j] < arr[Index])
			{
				Index = j;
			}
		}
		swap(arr[Index], arr[i]);
	}
}
相关推荐
We་ct2 小时前
LeetCode 50. Pow(x, n):从暴力法到快速幂的优化之路
开发语言·前端·javascript·算法·leetcode·typescript·
潇洒畅想2 小时前
1.1 从∑到∫:用循环理解求和与累积
java·数据结构·python·算法
郝学胜-神的一滴3 小时前
[简化版 GAMES 101] 计算机图形学 04:二维变换上
c++·算法·unity·godot·图形渲染·unreal engine·cesium
ZC跨境爬虫3 小时前
海南大学交友平台开发实战day7(实现核心匹配算法+解决JSON请求报错问题)
前端·python·算法·html·json
计算机安禾3 小时前
【数据结构与算法】第41篇:图论(五):拓扑排序与关键路径
c语言·数据结构·c++·算法·图论·visual studio
Q741_1473 小时前
每日一题 力扣 1320. 二指输入的的最小距离 动态规划 C++ 题解
c++·算法·leetcode·动态规划
wfbcg3 小时前
每日算法练习:LeetCode 76. 最小覆盖子串 ✅
算法·leetcode·职场和发展
Wect3 小时前
LeetCode 149. 直线上最多的点数:题解深度剖析
前端·算法·typescript
qianpeng8973 小时前
运动声源的到达结构仿真
算法