• 【排序】详解冒泡排序


    一、思想

    冒泡排序的基本思想是利用两两比较相邻记录的方式,通过一系列的比较和交换操作,使得较大或较小的元素逐渐移动到数列的一端。在每一轮的排序过程中,都会从数列的起始位置开始,对相邻的元素进行比较,如果它们的顺序不符合要求(例如,前一个元素大于后一个元素),则交换它们的位置。这样,每轮遍历后,至少会有一个元素被移动到其最终位置。重复这个过程,直到没有任何一对元素需要交换位置,即整个数组变为有序。

    冒泡排序的过程可以形象地比喻为水中的气泡上升过程,较小的元素逐渐“冒”到数列的顶端,而较大的元素则沉到底部。这个过程就像是在水中的气泡一样,不断向上冒出,直到所有的气泡都排好序。

    冒泡排序的时间复杂度为O(n^2),这使得它在处理大规模数据时效率不高。尽管如此,由于其实现简单,对于小规模数据集或者基本有序的数组,冒泡排序仍然是一个不错的选择。

    二、图解

    i指针控制次数,j指针每次遍历时进行两两比较,j每遍历一遍都会将一个最大的数排好序

    依次重复上述步骤,直到j遍历完n-1遍。如果一个数组本来就是有序或者经过小于n-1次就已经排好了序,那么j指针后续的遍历就是徒劳,所以我们可以根据j指针在遍历过程中是否有交换进行判断,如果没有交换说明已经排好序,这个时候就可直接返回

    三、代码实现
    1. void bubble_sort(vector<int>& arr) {
    2. for (int i = 0; i < arr.size(); i++) {
    3. bool f = false;
    4. for (int j = 0; j < arr.size() - i - 1; j++) {
    5. if (arr[j] > arr[j + 1]) {
    6. swap(arr[j], arr[j + 1]);
    7. f = true;
    8. }
    9. }
    10. if (!f) return;
    11. }
    12. }
    1. public static void bubbleSort(int[] arr) {
    2. for (int i = 0; i < arr.length; i++) {
    3. boolean f = true;
    4. for (int j = 0; j < arr.length - i - 1; j++) {
    5. if (arr[j] > arr[j + 1]) {
    6. f = false;
    7. swap(arr, j, j + 1);
    8. }
    9. }
    10. if (f) {
    11. break;
    12. }
    13. }
    14. }
  • 相关阅读:
    【微机接口】中断系统:中断的应用
    Redis数据持久化
    图形库实战丨C语言扫雷小游戏(超2w字,附图片素材)
    01背包(一) 01背包(二)动态规划
    数据结构与算法之时间复杂度和空间复杂度(C语言版)
    MVC模式认识
    SQL 汇总统计及GROUP BY
    2022牛客暑期多校训练营4(总结+补题)
    前端图片压缩解决办法
    动态规划(蓝桥杯 C++ 题目 代码 注解)
  • 原文地址:https://blog.csdn.net/qq_61903414/article/details/136487153