发布时间:2026/7/5 15:00:52
C语言 冒泡排序
冒泡排序:是一种简单直观的排序算法核心思想是通过多次遍历数组将较大的元素逐步“冒泡”到数组的末尾最终实现排序。它的名字来源于排序过程中较大的元素像气泡一样逐渐上浮的过程。算法原理:冒泡排序通过比较相邻的两个元素如果前一个元素比后一个元素大则交换它们的位置。每一轮遍历后当前未排序部分的最大值会被移动到数组的末尾。重复这一过程直到整个数组有序。假设这里有一组数据需要排成升序。确定要排几趟可以发现这 10 个数字需要 9 趟排序。排序把 9个数字都放在这 9 个数字应该出现的位置上最后 10 个数字自然地也出现在它应该出现的位置。如果是 n 个元素那么就需要 n-1 趟冒泡排序。确定要比较级个元素10 个数字需要 9 对相邻的元素进行比较排完 1 趟9来到想要的位置下次比较相临元素的对数-1。下一趟9 个元素比较8 对相邻元素比较。排完第2趟8来到想要的位置下次比较相临元素的对数-1。由此可知每排序一次需要比较相邻元素的对数-1。{ int i 0; // sz 计算元素个数 int sz sizeof(arr) / sizeof(arr[0]); //确定趟数 for (i 0; i sz - 1; i) { int j 0; //确定比较相邻元素的对数 for (j 0; j sz - 1 - i; j) { if (arr[j] arr[j 1]) { int tmp arr[j 1]; arr[j 1] arr[j]; arr[j] tmp; } } } } int main() { int arr[] { 9,8,7,6,5,4,3,2,1,0 }; bubble_sort(arr); int i 0; for (i 0; i 10; i) { printf(%d , arr[i]); } return 0; }sz-1: 最多访问到最后一个元素的下标 ;sz - 1 - j : 减去个 j , 做到每排完一趟需要比较的元素的对数就-1。第一趟是 10-1-0。j 是 010个元素有9对。第一趟是 10-1-1。j 是 19个元素有8对。......依此类推。运行下看结果。发现欸不对啊怎么没排序呢。我来找下猫腻。我们说传参传个数组名传的是首元素的地址。int arr[ ] 里存的是数组首元素地址。我们来看下内存。这是没进入bubble_sort 之前的首元素地址。这是进入函数形参和sz里存的东西一看,sz怎么是1不是我要的10啊。下面来解释你给我传了个地址 那我得用指针接收。int arr[ ] 本质是指针变量 等价于 int * arr那这在计算元素个数时就要出大问题了。我们说指针变量的大小是4或8个字节。在32位机器下是4个字节在64机器下是8个字节。sz在计算的时候用指针变量的大小除以了第一个元素大小这里是32位环境指针变量是4字节就计算出来是1如果是64 位环境下指针变量是8字节那结果就是2。所以这里的sz就是1了那么sz-1即1-10。根本没有进循环。再打印的时候也会就是原来的数组了。这里呢有个 t i p:建议不要在函数内部计算元素个数建议再传参的时候把元素分数传过去直接使用。这里找到问题这次在函数外面求sz。void bubble_sort(int arr[], int sz) { int i 0; for (i 0; i sz - 1; i) { int j 0; for (j 0; j sz - 1 - i; j) { if (arr[j] arr[j 1]) { int tmp arr[j 1]; arr[j 1] arr[j]; arr[j] tmp; } } } } int main() { int arr[] { 1,2,3,4,5,6,7,8,9,0 }; int sz sizeof(arr) / sizeof(arr[0]);//计算元素分数 bubble_sort(arr, sz); int i 0; for (i 0; i 10; i) { printf(%d , arr[i]); } return 0; }这次的结果呢这次正确了。看来问题已经解决了。那么以上就是冒泡排序的基本思想和实现。

相关新闻

D2 select/poll/epoll
2026/7/5 14:00:52

D2 select/poll/epoll

注意两个点客户端断开fd的值0:stdin;1:stdout;2:stderr;递增,回收后复用限制1024个,ulimit -n 65536:提升到65536个IO多复用复用一个线程,去同时检测多路是否有IO事件就绪select通过传入位图,内核遍历位图,…

阅读更多
暑假到了,小孩子(6-9 岁)如何学积木图形化编程?
2026/7/5 14:00:52

暑假到了,小孩子(6-9 岁)如何学积木图形化编程?

暑假到了,小孩子(6-9 岁)如何学积木图形化编程? 暑假到了,孩子空余时间多了,很多家长头疼孩子天天刷短视频,或到处闲逛,暑假确实是培养孩子兴趣的好时机,如果孩子喜欢动…

阅读更多
057、EDVR 模型:多帧对齐与时空注意力在视频超分中的应用
2026/7/5 14:00:52

057、EDVR 模型:多帧对齐与时空注意力在视频超分中的应用

057、EDVR 模型:多帧对齐与时空注意力在视频超分中的应用从一次视频超分翻车现场说起 去年有个项目,客户要求把一段监控录像从720p提升到4K。我一开始图省事,直接用单帧超分模型逐帧处理。结果呢?画面是清晰了,但视频播…

阅读更多
快速掌握Crypto++:免费C++加密库的完整配置指南
2026/7/5 16:00:53

快速掌握Crypto++:免费C++加密库的完整配置指南

快速掌握Crypto:免费C加密库的完整配置指南 【免费下载链接】cryptopp free C class library of cryptographic schemes 项目地址: https://gitcode.com/gh_mirrors/cr/cryptopp Crypto是一个功能强大的免费C加密库,为开发者提供了丰富的密码学算…

阅读更多
F3闪存检测工具:3分钟识别扩容盘的终极解决方案 [特殊字符]
2026/7/5 16:00:53

F3闪存检测工具:3分钟识别扩容盘的终极解决方案 [特殊字符]

F3闪存检测工具:3分钟识别扩容盘的终极解决方案 🔍 【免费下载链接】f3 F3 - Fight Flash Fraud 项目地址: https://gitcode.com/gh_mirrors/f3/f3 你是否曾遇到过新买的U盘或SD卡价格便宜得离谱,但存储重要文件时却频繁出现损坏&…

阅读更多
显卡驱动卸载终极指南:5分钟学会使用DDU彻底清理驱动残留
2026/7/5 16:00:53

显卡驱动卸载终极指南:5分钟学会使用DDU彻底清理驱动残留

显卡驱动卸载终极指南:5分钟学会使用DDU彻底清理驱动残留 【免费下载链接】display-drivers-uninstaller Display Driver Uninstaller (DDU) a driver removal utility / cleaner utility 项目地址: https://gitcode.com/gh_mirrors/di/display-drivers-uninstall…

阅读更多
洛雪音乐音源完整配置指南:5分钟实现全网无损音乐自由
2026/7/5 16:00:53

洛雪音乐音源完整配置指南:5分钟实现全网无损音乐自由

洛雪音乐音源完整配置指南:5分钟实现全网无损音乐自由 【免费下载链接】lxmusic- lxmusic(洛雪音乐)全网最新最全音源 项目地址: https://gitcode.com/gh_mirrors/lx/lxmusic- 还在为不同音乐平台的会员费烦恼吗?想要免费享受酷我、酷狗、QQ音乐、…

阅读更多
Apriori算法 Python 3.11 实战:从0到1构建购物篮分析模型,产出26条强规则
2026/7/5 16:00:52

Apriori算法 Python 3.11 实战:从0到1构建购物篮分析模型,产出26条强规则

Apriori算法Python 3.11实战:从零构建购物篮分析引擎与26条强规则解析1. 关联规则挖掘的商业价值与技术本质在零售业数字化转型的浪潮中,购物篮分析已成为优化商品布局、提升客单价的秘密武器。想象一下这样的场景:当顾客将啤酒放入购物车时&…

阅读更多
5个理由告诉你为什么Altium Designer元件库能让你告别设计焦虑
2026/7/5 15:00:52

5个理由告诉你为什么Altium Designer元件库能让你告别设计焦虑

5个理由告诉你为什么Altium Designer元件库能让你告别设计焦虑 【免费下载链接】AltiumDesigner-Libraries Personal schematic symbol and footprint libraries for Altium Designer. 项目地址: https://gitcode.com/gh_mirrors/al/AltiumDesigner-Libraries 作为一名电…

阅读更多
通达OA SQL注入漏洞深度剖析:从手工注入到自动化利用与防御
2026/7/5 0:00:50

通达OA SQL注入漏洞深度剖析:从手工注入到自动化利用与防御

1. 项目概述与漏洞背景最近在梳理一些历史OA系统的安全风险时,通达OA v11.6版本中的一个老漏洞又进入了我的视线。这个漏洞位于/general/bi_design/appcenter/report_bi.func.php文件中,是一个典型的SQL注入点。虽然这个漏洞的利用方式看起来并不复杂&am…

阅读更多
3步彻底解决Windows右键菜单混乱问题:ContextMenuManager使用全攻略
2026/7/5 0:00:50

3步彻底解决Windows右键菜单混乱问题:ContextMenuManager使用全攻略

3步彻底解决Windows右键菜单混乱问题:ContextMenuManager使用全攻略 【免费下载链接】ContextMenuManager 🖱️ 纯粹的Windows右键菜单管理程序 项目地址: https://gitcode.com/gh_mirrors/co/ContextMenuManager 你是否曾为Windows右键菜单中那些…

阅读更多
GXDE OS下Wayland兼容性实战:从deepin-mutter原理到VMware Tools修复
2026/7/5 0:00:50

GXDE OS下Wayland兼容性实战:从deepin-mutter原理到VMware Tools修复

如果你正在用 GXDE OS 或者任何基于 Deepin 的发行版,并且遇到了“检测到窗口系统采用 Wayland 协议,程序即将退出”这类弹窗,或者发现 VMware Tools 在 Ubuntu 24.04 这类默认 Wayland 的系统上启动失败,那这篇文章就是为你准备的…

阅读更多
通达OA SQL注入漏洞深度剖析:从手工注入到自动化利用与防御
2026/7/5 0:00:50

通达OA SQL注入漏洞深度剖析:从手工注入到自动化利用与防御

1. 项目概述与漏洞背景最近在梳理一些历史OA系统的安全风险时,通达OA v11.6版本中的一个老漏洞又进入了我的视线。这个漏洞位于/general/bi_design/appcenter/report_bi.func.php文件中,是一个典型的SQL注入点。虽然这个漏洞的利用方式看起来并不复杂&am…

阅读更多
3步彻底解决Windows右键菜单混乱问题:ContextMenuManager使用全攻略
2026/7/5 0:00:50

3步彻底解决Windows右键菜单混乱问题:ContextMenuManager使用全攻略

3步彻底解决Windows右键菜单混乱问题:ContextMenuManager使用全攻略 【免费下载链接】ContextMenuManager 🖱️ 纯粹的Windows右键菜单管理程序 项目地址: https://gitcode.com/gh_mirrors/co/ContextMenuManager 你是否曾为Windows右键菜单中那些…

阅读更多
GXDE OS下Wayland兼容性实战:从deepin-mutter原理到VMware Tools修复
2026/7/5 0:00:50

GXDE OS下Wayland兼容性实战:从deepin-mutter原理到VMware Tools修复

如果你正在用 GXDE OS 或者任何基于 Deepin 的发行版,并且遇到了“检测到窗口系统采用 Wayland 协议,程序即将退出”这类弹窗,或者发现 VMware Tools 在 Ubuntu 24.04 这类默认 Wayland 的系统上启动失败,那这篇文章就是为你准备的…

阅读更多
基于Dify与DeepSeek构建私有知识库问答系统实战指南
2026/7/4 11:17:16

基于Dify与DeepSeek构建私有知识库问答系统实战指南

在业务中快速构建一个能理解私有文档、准确回答专业问题的智能助手,是很多开发团队面临的共同挑战。传统方案往往需要从零开始搭建复杂的 RAG(检索增强生成)系统,涉及文档解析、向量化、检索、大模型调用等多个环节,整…

阅读更多
FAE放射组学分析工具:医学影像特征探索的完整解决方案
2026/7/4 5:24:16

FAE放射组学分析工具:医学影像特征探索的完整解决方案

FAE放射组学分析工具:医学影像特征探索的完整解决方案 【免费下载链接】FAE FeAture Explorer 项目地址: https://gitcode.com/gh_mirrors/fae/FAE 你是否曾经面对海量医学影像数据感到无从下手?想要从CT、MRI等影像中提取有价值的定量特征&#…

阅读更多
DesktopNaotu:你的终极离线思维导图解决方案,告别网络依赖!
2026/7/5 15:33:35

DesktopNaotu:你的终极离线思维导图解决方案,告别网络依赖!

DesktopNaotu:你的终极离线思维导图解决方案,告别网络依赖! 【免费下载链接】DesktopNaotu 桌面版脑图 (百度脑图离线版,思维导图) 跨平台支持 Windows/Linux/Mac OS. (A cross-platform multilingual Mind Map Tool) 项目地址:…

阅读更多