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

相关推荐
happymaker06262 小时前
LeetCodeHot100——42.接雨水
算法
阿正的梦工坊3 小时前
【Rust】07-错误处理:Option、Result 与 ? 运算符
开发语言·算法·rust
烬羽3 小时前
从零理解树与二叉树:用 JS 带你手撕遍历和递归
javascript·数据结构
YHL3 小时前
🚀从零理解树与二叉树 —— 概念、实现与遍历
前端·javascript·数据结构
JieE2123 小时前
JS 到底有多少种数据类型?从ECMA规范到内存本质,一文彻底搞懂
javascript·数据结构·面试
努力努力再努力wz4 小时前
【内存管理与高并发内存池系列】从 mmap 到 malloc:文件映射、匿名映射与 glibc 内存分配机制详解
linux·c语言·数据结构·数据库·c++·qt·链表
J2虾虾4 小时前
C 语言 void 完全用法
c语言·开发语言
八解毒剂4 小时前
数据结构-平衡二叉树——对二叉搜索树的优化
数据结构·c++·算法
wu_ye_m4 小时前
学习c语言第35天 函数声明和定义
c语言·开发语言·学习
运行时记录4 小时前
别再手动写提示词了 — SkillOpt 让技能文档自己进化
算法