0

0

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

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-02-03 15:45:11

|

870人浏览过

|

来源于php中文网

原创

外层循环最多执行 n-1 次,因每轮将当前未排序部分最大值移至末尾,n 个元素只需确定前 n-1 个位置;内层循环上限应为 n-1-i,确保 j+1 不越界。

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

冒泡排序在 C++ 里用双重 for 循环就能实现,但新手常写成死循环、越界或无效交换——关键不在“能跑”,而在理解每层循环的边界和终止条件。

为什么外层循环最多执行 n-1

每次外层循环结束,都会把当前未排序部分的最大值“冒泡”到末尾。n 个元素,最多需要确定前 n-1 个位置(最后一个自然就位),所以外层循环次数是 i = 0; i 。

如果写成 i ,最后一次循环不会发生任何交换,纯属冗余;更糟的是,若内层循环没同步收缩边界,可能引发越界。

  • 数组长度为 n,合法下标是 0n-1
  • 内层循环比较 arr[j]arr[j+1],所以 j 最大只能取 n-2
  • 因此内层上限应设为 n - 1 - i,随外层推进逐步缩小范围

std::vector 和原生数组的写法差异

std::vector 更安全,可直接调 .size();原生数组传入函数后会退化为指针,必须额外传长度。

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

错误示范(原生数组):

void bubbleSort(int arr[]) { // ❌ 无法获取长度
    int n = sizeof(arr) / sizeof(arr[0]); // 这里得到的是指针大小,不是数组长度
}

正确做法:

魔匠AI论文
魔匠AI论文

专业原创的AI论文写作工具,一站式解决论文选题、写作、文献综述、答辩PPT全流程,支持毕业论文、课程论文等多种类型,轻松助力高质量论文写作。

下载
  • std::vector:用 v.size()
  • 对原生数组:函数签名写成 void bubbleSort(int arr[], int n)
  • 或用模板 + 引用避免退化:template void bubbleSort(int (&arr)[N])

交换逻辑必须加 if 判断,不能无条件 swap

冒泡排序的核心是“相邻比较 + 逆序交换”。跳过 if (arr[j] > arr[j+1]) 直接 swap,会导致顺序变乱,甚至把最小值反复推到末尾。

常见误写:

swap(arr[j], arr[j+1]); // ❌ 缺少条件判断,逻辑完全错误

正确结构:

  • 内层循环中,只在 arr[j] > arr[j+1] 时交换
  • 可选优化:记录是否发生交换,某轮全无交换则提前退出(bool swapped 标志)
  • 不加 if 的“冒泡”不是排序,是随机扰动

容易被忽略的边界:内层循环上限是 n - 1 - i,不是 n - i

因为要访问 arr[j+1],j 的最大合法值是 n-2。当外层执行第 i 轮(i 从 0 开始),末尾已有 i 个元素有序,剩余待排长度为 n - i,那么 j 最大只能到 (n - i) - 2 = n - i - 2,所以内层循环应写成 for (int j = 0; j 。

写成 j 会导致 j+1 == n - i,越界访问(尤其当 i == 0 时,就是访问 arr[n])。

这个 -1 不是凭空加的,它来自对 j+1 下标安全性的硬性约束。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

790

2023.08.22

string转int
string转int

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

543

2023.08.02

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

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

547

2024.08.29

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

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

153

2025.08.29

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

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

201

2025.08.29

javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

177

2023.11.23

java中void的含义
java中void的含义

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

103

2025.11.27

AO3官网入口与中文阅读设置 AO3网页版使用与访问
AO3官网入口与中文阅读设置 AO3网页版使用与访问

本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

89

2026.02.02

主流快递单号查询入口 实时物流进度一站式追踪专题
主流快递单号查询入口 实时物流进度一站式追踪专题

本专题聚合极兔快递、京东快递、中通快递、圆通快递、韵达快递等主流物流平台的单号查询与运单追踪内容,重点解决单号查询、手机号查物流、官网入口直达、包裹进度实时追踪等高频问题,帮助用户快速获取最新物流状态,提升查件效率与使用体验。

24

2026.02.02

热门下载

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

精品课程

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

共578课时 | 56.5万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1.0万人学习

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

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