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[ ]看似是数组,本质上是指针变量,所以不能在函数内部计算数组的大小,可以在主函数内计算了之后通过传参传递到函数内部。

相关推荐
ZHANG13HAO12 小时前
蚁群算法(蚁聚算法)深度解析与 mTSP 实战:物流多车协同配送优化
人工智能·算法·机器学习
D_C_tyu12 小时前
HTML | 基于权重评估算法实现自动游戏功能的俄罗斯方块小游戏
算法·游戏·html
BUTCHER512 小时前
G1数据结构
数据结构
小肝一下12 小时前
每日两道力扣,day1
算法·leetcode·职场和发展
WBluuue12 小时前
AtCoder Beginner Contest 451(ABCDEFG)
c++·算法
im_AMBER12 小时前
Leetcode 151 最大正方形 | 买卖股票的最佳时机 III
数据结构·算法·leetcode·动态规划
Fly Wine12 小时前
Leetcode之简单题:在区间范围内统计奇数数目
算法·leetcode·职场和发展
CoderCodingNo12 小时前
【GESP】C++五级练习题 luogu-P1102 A-B 数对
开发语言·c++·算法
切糕师学AI12 小时前
深入理解倒排索引(Inverted Index):搜索引擎的核心数据结构
数据结构·搜索引擎·inverted-index
cpp_250113 小时前
B3873 [GESP202309 六级] 小杨买饮料
数据结构·c++·算法·动态规划·题解·洛谷