0

0

C++ 怎么实现冒泡排序 C++经典排序算法手写代码【新手】

穿越時空

穿越時空

发布时间:2026-01-31 12:02:54

|

926人浏览过

|

来源于php中文网

原创

冒泡排序需外层n-1轮、内层每轮范围递减,交换条件为arr[j] > arr[j+1](升序),且j+1

c++ 怎么实现冒泡排序 c++经典排序算法手写代码【新手】

冒泡排序的核心逻辑怎么写才不出错

冒泡排序本质是重复比较相邻元素并交换,让较大(或较小)的值像气泡一样“浮”到一端。关键不是背代码,而是理解每轮 for 循环的边界和交换条件。

  • 外层循环控制“轮数”,共 n-1 轮就够了(最后一轮只剩一个元素无需比较)
  • 内层循环控制“当前轮中比较的范围”,每轮后末尾已有序,所以每次上限减 1:用 j ,别写成 j
  • 交换只在 arr[j] > arr[j + 1] 时发生(升序),注意下标别越界——j + 1 要小于 n

手写时最容易踩的数组越界和索引错误

新手常把内层循环写成 for (int j = 0; j ,然后在循环里访问 arr[j+1],导致访问 arr[n]——这是未定义行为,可能崩溃或输出乱码。

  • 正确写法必须保证 j + 1 ,即 j ;再结合每轮缩小范围,就是 j
  • 如果用 std::vector,记得用 .size() 获取长度,并强转为 int 或用有符号类型比较,避免无符号整数下溢(比如 0 - 1 变成极大正数)
  • 调试时可在循环开头加 std::cout 快速定位越界位置

用 vector 还是原生数组?参数传递怎么选

对新手更安全的是传 std::vector&,避免指针和长度分离带来的管理负担;但如果练基本功,用原生数组要显式传长度,不能只传 int arr[](它会退化为指针,丢失大小)。

  • 推荐函数签名:void bubbleSort(std::vector& arr)void bubbleSort(int arr[], int n)
  • 别写 void bubbleSort(int arr[]) —— 编译器不检查长度,你无法知道数组多大
  • 如果函数内需要拷贝一份做测试,用 std::vector temp = arr;,别用 memcpy 操作 vector 内部指针(不安全且没必要)

要不要加优化:提前终止的 flag 怎么设才有效

如果某轮没发生任何交换,说明已有序,可以提前退出。但 flag 的初始化和重置位置很关键,放错地方会让优化失效。

uBrand
uBrand

一站式AI品牌创建平台,在线品牌设计,AI品牌策划,智能品牌营销;uBrand帮助创业者轻松打造个性品牌!

下载

立即学习C++免费学习笔记(深入)”;

  • flag 必须在每轮外层循环开始前设为 false,并在发生交换时设为 true
  • 检查时机在内层循环结束后:if (!swapped) break;
  • 注意不要在内层循环里就 break 外层——C++ 没有标签 break,得靠 flag 控制
  • 这个优化对已排序或近似有序数据明显,但最坏情况(逆序)下仍为 O(n²),别误以为加了 flag 就变快了

实际写的时候,先跑通无 flag 版本,再加 flag;测试用例至少包括空数组、单元素、已排序、完全逆序、含重复数这五种情况。边界比算法本身更容易出问题。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

483

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

545

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

113

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

200

2025.08.29

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

416

2023.08.14

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

31

2026.01.31

高干文在线阅读网站大全
高干文在线阅读网站大全

汇集热门1v1高干文免费阅读资源,涵盖都市言情、京味大院、军旅高干等经典题材,情节紧凑、人物鲜明。阅读专题下面的文章了解更多详细内容。

20

2026.01.31

无需付费的漫画app大全
无需付费的漫画app大全

想找真正免费又无套路的漫画App?本合集精选多款永久免费、资源丰富、无广告干扰的优质漫画应用,涵盖国漫、日漫、韩漫及经典老番,满足各类阅读需求。阅读专题下面的文章了解更多详细内容。

28

2026.01.31

漫画免费在线观看地址大全
漫画免费在线观看地址大全

想找免费又资源丰富的漫画网站?本合集精选2025-2026年热门平台,涵盖国漫、日漫、韩漫等多类型作品,支持高清流畅阅读与离线缓存。阅读专题下面的文章了解更多详细内容。

4

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 8.1万人学习

C 教程
C 教程

共75课时 | 4.3万人学习

C++教程
C++教程

共115课时 | 14.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号