0

0

C++ 怎么实现冒泡排序 C++ 双重循环排序算法逻辑详解【新手】

穿越時空

穿越時空

发布时间:2026-01-27 12:57:08

|

993人浏览过

|

来源于php中文网

原创

冒泡排序需确保内层循环边界为j arr[j + 1],否则易致越界或不稳定;升序稳定版必须用>而非>=,降序则用

c++ 怎么实现冒泡排序 c++ 双重循环排序算法逻辑详解【新手】

冒泡排序在 C++ 里用双重 for 循环就能写出来,但新手常写成死循环、越界访问,或根本排不成功——问题大多出在内层循环边界和交换条件上。

为什么 i 而不是 i ?

外层循环控制“轮数”,每轮把当前未排序部分的最大值“冒”到末尾。n 个元素最多需要 n−1 轮就可完成排序(最后一轮只剩一个元素,无需比较)。若写成 i ,最后一轮会做无意义的空循环,虽不报错但效率低;更危险的是,若内层循环没同步收缩范围,可能引发越界。

  • 正确写法:for (int i = 0; i
  • 错误典型:for (int i = 0; i (多跑一轮,且易导致内层 j 下溢)

for (int j = 0; j 中的 n - i - 1 怎么来的?

每轮结束后,末尾 i+1 个位置已有序(第 0 轮后最大值到位,第 1 轮后次大值到位……)。所以第 i 轮只需比较前 n - i 个元素,而相邻比较需索引 jj+1 都有效,因此 j 最大只能取到 n - i - 2,即 j 。

  • 若写成 j :当 j == n - i - 1 时,arr[j+1] 就是 arr[n - i],越界
  • 若写成 j :每轮都扫全数组,不仅重复比较已排序部分,还会在后期必然越界

交换逻辑必须用 arr[j] > arr[j + 1],不能反着写

冒泡排序默认升序,核心是“前大后小则交换”。若写成 ,就会变成降序;若漏掉等号(比如写成 >=),遇到相等元素时仍交换,破坏稳定性(相同值的相对顺序会变)——虽然对纯数值影响小,但一旦元素是自定义结构体,稳定性就很重要。

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

  • 升序稳定版:用 if (arr[j] > arr[j + 1])
  • 降序:用 if (arr[j]
  • 别用 >=,除非你明确要非稳定排序

完整可运行示例(带注释)

#include 
#include 
using namespace std;

void bubbleSort(vector& arr) { int n = arr.size(); for (int i = 0; i < n - 1; ++i) { // 外层:共 n-1 轮 for (int j = 0; j < n - i - 1; ++j) { // 内层:每轮少比 1 个 if (arr[j] > arr[j + 1]) { // 升序,前大于后才交换 swap(arr[j], arr[j + 1]); } } } }

int main() { vector a = {64, 34, 25, 12, 22, 11, 90}; bubbleSort(a); for (int x : a) cout << x << " "; // 输出:11 12 22 25 34 64 90 }

真正容易被忽略的不是怎么写,而是每次改循环边界时是否同步检查了数组访问下标——哪怕只多加一个 1 或少减一个 1,都可能让程序在小数据上正常、大数据上崩溃。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
c++和c语言的区别有哪些
c++和c语言的区别有哪些

c++和c语言的区别:1、面向对象编程(OOP)支持不同;2、新增特性不同;3、标准库不同;4、编译方式不同;5、命名空间不同等等。想了解更多c++的相关内容,可以阅读本专题下面的文章。

258

2024.03.14

c++和python学习顺序推荐
c++和python学习顺序推荐

一般建议先学习C++,再学习Python,因为这样可以逐步从较为底层的编程语言向更高级的语言过渡。想了解更多python的相关内容,可以阅读本专题下面的文章。

423

2024.03.14

python和c++学习性价比分析
python和c++学习性价比分析

Python易于学习,广泛应用于Web开发、数据科学和人工智能等领域,但性能较低。C语言性能高,适用于对性能要求较高的场景,如游戏开发和系统编程,但学习曲线陡峭,错误处理复杂。想了解更多python的相关内容,可以阅读本专题下面的文章。

103

2024.03.14

c语言和c++一样吗
c语言和c++一样吗

c语言和c++是两种不同的编程语言,虽然有相似之处,但存在显著差异。c语言专注于过程式编程和系统级开发,以简洁、高效著称。c++作为c语言的超集,引入了面向对象编程,增强了代码组织和管理能力,但学习曲线也更陡峭。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

135

2024.03.14

c语言和c++先学哪个好
c语言和c++先学哪个好

初学者选择学习c语言还是c++语言,需要根据个人学习目标、背景以及编程兴趣和预期应用方向来决定。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

101

2024.03.14

c语言和c++的区别和联系
c语言和c++的区别和联系

c语言和c++是计算机科学领域应用广泛的编程语言。虽然它们有着相似的基础,但它们在语言类型、语法功能和内存管理方面存在着显著差异。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

123

2024.03.14

c++软件中文更改教程
c++软件中文更改教程

对于 ide,可通过打开设置,找到语言设置,选择中文,并保存更改。对于非 ide 应用程序,可查找设置或选项,选择语言设置,更改为中文,并保存更改。想了解更多c++的相关内容,可以阅读本专题下面的文章。

303

2024.03.21

python和java和c++学习性价比分析
python和java和c++学习性价比分析

Python以其易学性、丰富的库和活跃的社区而著称,适合数据科学、人工智能和Web开发。Java以其跨平台性、企业级应用开发和Android应用开发而闻名。C++以其底层控制能力、高效性能和游戏开发而著称。选择哪种语言取决于个人兴趣、职业方向和特定需求。想了解更多python和java和c++的相关内容,可以阅读本专题下面的文章。

335

2024.03.22

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

2

2026.01.27

热门下载

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

精品课程

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

共18课时 | 4.9万人学习

PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.9万人学习

Django 教程
Django 教程

共28课时 | 3.5万人学习

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

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