0

0

C++如何实现冒泡排序 C++冒泡排序的算法与代码示例

穿越時空

穿越時空

发布时间:2025-08-13 18:43:01

|

336人浏览过

|

来源于php中文网

原创

冒泡排序的时间复杂度在最好情况下是o(n),当数组已经有序时只需遍历一次;最坏情况下是o(n^2),当数组完全逆序时需进行n-1趟比较;平均情况也是o(n^2)。优化方式包括引入swapped标志以检测是否提前完成排序,从而减少不必要的遍历。应用场景包括教学示例、数据量小或基本有序的情况,以及对性能要求不高的项目中。

C++如何实现冒泡排序 C++冒泡排序的算法与代码示例

C++实现冒泡排序,核心在于通过相邻元素的比较和交换,逐步将最大(或最小)的元素“冒泡”到序列的顶端。理解比较和交换的逻辑是关键。

C++如何实现冒泡排序 C++冒泡排序的算法与代码示例
#include 
#include 

void bubbleSort(std::vector& arr) {
    int n = arr.size();
    bool swapped;
    for (int i = 0; i < n - 1; i++) {
        swapped = false;
        for (int j = 0; j < n - i - 1; j++) {
            if (arr[j] > arr[j + 1]) {
                std::swap(arr[j], arr[j + 1]);
                swapped = true;
            }
        }
        // 如果在一趟排序中没有发生交换,说明数组已经有序
        if (swapped == false)
            break;
    }
}

int main() {
    std::vector data = {64, 34, 25, 12, 22, 11, 90};
    bubbleSort(data);
    std::cout << "排序后的数组:\n";
    for (int i = 0; i < data.size(); i++)
        std::cout << data[i] << " ";
    std::cout << std::endl;
    return 0;
}

C++冒泡排序的算法与代码示例

C++如何实现冒泡排序 C++冒泡排序的算法与代码示例

冒泡排序的时间复杂度是多少?最好、最坏和平均情况分别是什么?

冒泡排序的时间复杂度分析起来挺有意思。最好情况下,如果数组已经是排序好的,只需要遍历一次即可确认,时间复杂度是O(n)。最坏情况下,数组是完全逆序的,需要进行n-1趟排序,每趟排序进行n-i-1次比较,时间复杂度是O(n^2)。平均情况下,时间复杂度也是O(n^2)。所以,在数据量大的时候,冒泡排序效率确实不高。

Beautiful.ai
Beautiful.ai

AI在线创建幻灯片

下载

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

C++如何实现冒泡排序 C++冒泡排序的算法与代码示例

如何优化冒泡排序,使其在某些情况下更快?

优化冒泡排序,一个常见的技巧是引入一个

swapped
标志。如果在一次完整的遍历中,没有发生任何交换,那么说明数组已经是有序的,可以直接结束排序。就像代码示例里展示的那样。 这种优化对于部分有序的数组效果明显,可以提前结束排序过程。当然,即使做了优化,最坏情况下的时间复杂度仍然是O(n^2)。

冒泡排序在实际项目中的应用场景有哪些?

虽然冒泡排序效率不高,但在某些特定场景下还是有它的用武之地的。比如,当数据量很小,或者数组已经基本有序时,冒泡排序的实现简单和易于理解的优点就体现出来了。此外,冒泡排序还可以作为教学示例,帮助初学者理解排序算法的基本思想。在实际项目中,如果对性能要求不高,或者只需要对少量数据进行排序,冒泡排序也是一个可行的选择。

相关专题

更多
页面置换算法
页面置换算法

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

405

2023.08.14

c++ 根号
c++ 根号

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

45

2026.01.23

c++空格相关教程合集
c++空格相关教程合集

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

46

2026.01.23

yy漫画官方登录入口地址合集
yy漫画官方登录入口地址合集

本专题整合了yy漫画入口相关合集,阅读专题下面的文章了解更多详细内容。

205

2026.01.23

漫蛙最新入口地址汇总2026
漫蛙最新入口地址汇总2026

本专题整合了漫蛙最新入口地址大全,阅读专题下面的文章了解更多详细内容。

343

2026.01.23

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

16

2026.01.23

php远程文件教程合集
php远程文件教程合集

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

100

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

73

2026.01.22

php会话教程合集
php会话教程合集

本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

78

2026.01.22

热门下载

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

精品课程

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

共94课时 | 7.5万人学习

C 教程
C 教程

共75课时 | 4.2万人学习

C++教程
C++教程

共115课时 | 13.7万人学习

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

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