排序算法【冒泡排序】

一、原理

冒泡排序的原理比较简单,就是将待排序区域的数值挨个向后对比,直到比较到已排序的边界,就纳入已排序区域。

二、代码如下所示:

cpp 复制代码
#include <stdio.h>
#include "test.h"

/* 冒泡排序 */
void bubble_sort(int* arr, int begin, int len)
{
	int data;
	for (int i = len; i > begin; i--)      //外层循环决定内层的遍历次数,每循环一次,就减少一次遍历
	{
		for (int j = begin; j < i-1; j++)  //内层根据遍历次数进行数据比较
		{
			if (arr[j] > arr[j + 1])
			{
				data = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = data;
			}
		}
	}
}


void main()
{
	int* arr = CreateArray(10000);
	//TEST_MY(selection_sort, arr, 10000);
	TEST_MY(bubble_sort, arr, 10000);
	/*unguarded_insert_sort(arr, 0, 10000, 1);*/
	//printf("data:%d, %d, %d, %d\r\n", arr[0], arr[1], arr[2], arr[3]);
	free(arr);
	return;
}

运行结果如下所示:

相关推荐
橘颂TA几秒前
【剑斩OFFER】算法的暴力美学——LeetCode 200 题:岛屿数量
算法·leetcode·职场和发展
苦藤新鸡3 分钟前
14.合并区间(1,3)(2,5)=(1,5)
c++·算法·leetcode·动态规划
程序员-King.13 分钟前
day145—递归—二叉树的右视图(LeetCode-199)
算法·leetcode·二叉树·递归
漫随流水17 分钟前
leetcode算法(112.路径总和)
数据结构·算法·leetcode·二叉树
过期的秋刀鱼!24 分钟前
机器学习-带正则化的成本函数-
人工智能·python·深度学习·算法·机器学习·逻辑回归
ScilogyHunter26 分钟前
前馈/反馈控制是什么
算法·控制
_OP_CHEN37 分钟前
【算法基础篇】(四十八)突破 IO 与数值极限:快速读写 +__int128 实战指南
c++·算法·蓝桥杯·算法竞赛·快速读写·高精度算法·acm/icpc
程序员泠零澪回家种桔子41 分钟前
RAG自查询:让AI精准检索的秘密武器
人工智能·后端·算法
糖葫芦君1 小时前
TRPO-trust region policy optimization论文讲解
人工智能·算法·机器学习·强化学习
HaiLang_IT1 小时前
基于RepVGG与注意力机制的手写潦草汉字识别算法研究
算法