排序算法—冒泡排序

,# 排序算法---冒泡排序

核心思想:两两相邻的元素进行比较,有需要的交换。

升序:一趟冒泡排序完成一个数字的排序,有n 个数字排序,需要进行n-1 次。

c 复制代码
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
//冒泡排序函数
void bublle_sort(int arr[], int sz)
{
	int i = 0;
		for (i = 0; i < sz - 1; i++)//外层排序趟数
		{
			int flag = 1;
			for (int j = 0; j < sz - 1 - i; j++)//内层排序细节
			{
				if (arr[j] > arr[j + 1])
				{
					int tmp = arr[j];
					arr[j] = arr[j + 1];
					arr[j + 1] = tmp;
					flag = 0;
				}
			}
			if(flag == 1)
				break;
		}
}
void print_arr(int arr[], int sz) {
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%d", arr[i]);
	}
	printf("\n ");
}
//主函数
#include <stdio.h>
int main()
{
	int arr[] = { 9,8,7,6,5,4,3,2,1,0 };
	int sz = sizeof(arr) / sizeof(arr[0]);
	//运行函数
	bublle_sort(arr, sz);
	print_arr(arr, sz);
	return 0;
}
相关推荐
小则又沐风a10 小时前
类和对象(C++)---上
java·c++·算法
季明洵10 小时前
动态规划及背包问题
java·数据结构·算法·动态规划·背包问题
busideyang11 小时前
函数指针类型定义笔记
c语言·笔记·stm32·单片机·算法·嵌入式
Wect11 小时前
LeetCode 215. 数组中的第K个最大元素:大根堆解法详解
前端·算法·typescript
深邃-11 小时前
数据结构-双向链表
c语言·开发语言·数据结构·c++·算法·链表·html5
2401_8785302111 小时前
分布式任务调度系统
开发语言·c++·算法
_深海凉_11 小时前
LeetCode热题100-两数之和
算法·leetcode·职场和发展
nunca_te_rindas11 小时前
算法刷体小结汇总(C/C++)20260328
c语言·c++·算法
Sunshine for you11 小时前
高性能压缩库实现
开发语言·c++·算法
Sunshine for you11 小时前
C++中的表达式模板
开发语言·c++·算法