图解算法系列之冒泡排序(优化版)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了图解算法系列之冒泡排序(优化版)相关的知识,希望对你有一定的参考价值。

算法描述

在第一层循环中设置一个变量,只要该序列局部有序就不需要进行排序了,提前终止循环。

图解算法

略.

C/C++代码实现

Custom.h

void BubbleSortAdvanced(int arr[], int number);

Custom.cpp

void BubbleSortAdvanced(int arr[], int number) {
    bool exchange;
    for(int i = 0; i < number; i++) {
        // 先设置为false
        exchange = false;
        for(int j = 0; j < number - 1; j++) {
            if(arr[j] > arr[j + 1]) {
                int temp = arr[j + 1];
                arr[j + 1] = arr[j];
                arr[j] = temp;
                // 如果有过一次改动表示这一个排序中所有数据是无序状态
                exchange = true;
            }
        }
        // 如果没有改动表示第一次在全局扫描所有元素的时候都是有序的不需要其他次数的扫描了
        if(!exchange) {
            return;
        }
    }
}

Java代码实现

public class BubbleSortAdvanced {
    public static void sort(int[] arr, int number) {
        boolean exchange;
        for (int i = 0; i < number; i++) {
            exchange = false;
            for (int j = 0; j < number-1; j++) {
                if (arr[j] > arr[j+1]) {
                    int temp = arr[j+1];
                    arr[j+1] = arr[j];
                    arr[j] = temp;
                    exchange = true;
                }
            }
            if (!exchange) {
                return;
            }
        }
    }
}

时间复杂度分析

最好情况下是O(n^2),但是数据如果本来有序就会提前结束。

以上是关于图解算法系列之冒泡排序(优化版)的主要内容,如果未能解决你的问题,请参考以下文章

图解算法系列之插入排序(优化版)

图解算法系列之插入排序(Low版)

排序算法之冒泡选择插入排序(Java)

排序算法之冒泡选择插入排序(Java)

八大排序算法C语言过程图解+代码实现(插入,希尔,选择,堆排,冒泡,快排,归并,计数)

(附代码)动图图解 | 十大经典排序算法Python版实现