冒泡排序改进方案

冒泡排序 BubbleSort

冒泡排序是一种比较简单的 稳定排序 算法,效率不高,因此实际当中用到的机会并不多。但
作为快速排序算法的基础,还是有必要了解一下。
顾名思义,冒泡就是指大的数字(气泡)会优先从底部升到顶端(大的数浮力较大,上升)。
具体实现的方式就是重复的 【交换排序】,通过两两比较不断地将大的数字右移。
具体看下面的GIF图就很清楚了。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

冒泡排序在 最坏情况下的时间复杂度是O(n²),
最坏的情况比如将一组降序排好的数据按升序排列。
下面是一个相对效率较高的冒泡排序实现,
通过设置一个标志位来控制提前跳出(跳过前面已经整体有序的序列)。
// 冒泡排序
void BubbleSort(int data[], int n)  
{  
    bool  swapped;// 有交换的标志 未出现有序的序列
    int temp_data;// 条换
    for(int i=n-1; i>=0; i--)// n行大排序
    {
        swapped = false;
        for(int j=0; j<i; j++)// i次交换排序
        {
            if (data[j+1] < data[j])// 前面的大,需要交换,移到后面
            {
                // 交换数据
                temp_data = data[j+1];
                data[j+1] = data[j];
                data[j] = temp_data;
                swapped = true;// 设置 未出现有序的序列 标志, 还需要继续执行
            }
        }
        if(false == swapped)
            break;
    }
}

改进2 跳过整体有序 + 跳过部分有序

// 冒泡排序
void BubbleSort(int data[], int n)  
{  
    bool  swapped;// 有交换的标志 未出现有序的序列
    int temp_data;// 条换
    for(int i=n-1; i>=0; i--)// n行大排序
    {
        int last = i;
        for(int j=0; j<i; j++)// i次交换排序
        {
            if (data[j+1] < data[j])// 前面的大,需要交换,移到后面
            {
                // 交换数据
                temp_data = data[j+1];
                data[j+1] = data[j];
                data[j] = temp_data;
                // swapped = true;// 设置 未出现有序的序列 标志, 还需要继续执行
                last = j;
            }
        }
        i = last;// 直接跳过后面已经有序的部分
        //if(false == swapped) break;
    }
}

改进3 鸡尾酒排序 左到右找最大,再从右到左找最小

  • 9
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值