C语言—冒泡排序

冒泡排序的核心思想:两个相邻的元素进行比较。

一趟冒泡排序让一个数据来到它最终应该出现的位置上。

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

void bubble_sort(int arr[],int sz)
{
	int i = 0;
	int j = 0;
	int t = 0;
	for(i = sz-1;i >= 0;i--)
		for(j = 0;j < i;j++)
			if(arr[j+1] < arr[j])
			{
				t = arr[j];
				arr[j] = arr[j+1];
				arr[j+1] = t;
			}
}

int main()
{
	int arr[10] = {10,2,3,14,5,6,17,8,9,1};
	int i = 0;
	int j = 0;
    int sz = sizeof(arr) / sizeof(arr[0]);
	bubble_sort(arr,sz);
	for(i = 0;i < 10;i++)
		printf("%d\n",arr[i]);
	return 0;
}

数组名本质上是:数组首元素的地址。

地址应该使用指针来接收,所以上面bubble_sort()函数中的形参int arr[ ]看似是数组,本质上是指针变量,所以不能在函数内部计算数组的大小,可以在主函数内计算了之后通过传参传递到函数内部。

相关推荐
念恒123061 分钟前
进程控制---进程程序替换
linux·c语言
谭欣辰6 分钟前
C++ 哈希表详解
c++·算法·哈希算法·散列表
shehuiyuelaiyuehao11 分钟前
算法11,滑动窗口,最大连续1的个数|||
算法·leetcode·职场和发展
南宫萧幕12 分钟前
车辆能量管理进阶:从前沿算法 (VMD-PPO-DBO) 机制解析到 MPC 工程建模
人工智能·算法·matlab·simulink·控制
三品吉他手会点灯18 分钟前
STM32 VSCode 开发-C语言程序运行后,终端中文乱码
c语言·ide·笔记·vscode·stm32·学习·编辑器
费曼学习法19 分钟前
快速选择算法:如何在 10 亿数据中瞬间找到“第 K 大”?
javascript·算法
如君愿19 分钟前
考研复习 Day 18 | 数据结构与算法--图(上)
数据结构·考研·记录考研
彷徨而立21 分钟前
【C/C++】在头文件中定义全局变量的方法
c语言·开发语言·c++
自我意识的多元宇宙29 分钟前
【数据结构】平衡二叉树
数据结构
|_⊙31 分钟前
C++ 哈希
算法·哈希算法·散列表