2018年4月20日 堆排序+冒泡(手写+转载)

本文详细探讨了两种经典排序算法——堆排序和冒泡排序。首先,介绍了堆排序的工作原理,包括如何构建最大堆以及如何通过交换堆顶元素实现排序。接着,详细解释了冒泡排序的过程,通过不断比较相邻元素并交换位置逐步达到排序目的。此外,还提供了这两种排序算法的代码实现,便于读者理解和应用。
摘要由CSDN通过智能技术生成
平均时间复杂度:O(nlogn) 最佳时间复杂度:O(nlogn) 最差时间复杂度:O(nlogn)  稳定性:不稳定
堆排序其实也是一种选择排序,是一种树形选择排序。只不过直接选择排序中,为了从R[1...n]中选择最大记录,需比较n-1次,
然后从R[1...n-2]中选择最大记录需比较n-2次。

事实上这n-2次比较中有很多已经在前面的n-1次比较中已经做过,而树形选择排序恰好利用树形的特点保存了部分前面的比较结果,
因此可以减少比较次数。对于n个关键字序列,最坏情况下每个节点需比较log2(n)次,因此其最坏情况下时间复杂度为nlogn。
堆排序为不稳定排序,不适合记录较少的排序。
#include <iostream>
#include <cstdio>
#include <algorithm>//c++11不需要 swap在std命名空间里面
/** 找到当前子树最大结点,放到父节点*/
void heapify(int arr[],int i,int len)
{
    if(i < len)
    {
        int right = 2*i+2;
        int left = 2*i+1;
        int max_value = i;
        if(right<len)
        {
            if(arr[right]>arr[max_value])
            {
                max_value = right;
            }
        }
        if(left < len)
        {
            if(arr[left]>arr[max_value])
            {
                max_value = left;
            }
        }
        if(max_value != i){
            std::swap(arr[i],arr[max_value]);
            /*int temp = arr[i];
            arr[i] = arr[max_value];
            arr[max_value] = temp;*/
            heapify(arr,max_value,len);
        }
    }
}
/** 建堆操作*/
void max_heapify(int arr[], int len){
    for(int i = len-1;i>=0;i--){
        heapify(arr,i,len);
    }
}
/**堆排序*/
void heap_sort(int arr[],int len){
    for(int i = len-1;i>=0;i--){
        max_heapify(arr,i+1);//缩减 i+1是当前数组的大小
        std::swap(arr[0],arr[i]);
        /*int temp = arr[0];
        arr[0] = arr[i];
        arr[i] = temp;*/
    }
}
// 冒泡排序改进②
// 记录某次遍历时最后发生数据交换的位置pos,
// 由于pos位置之后的记录均已有序(或者交换到位),故在进行下一趟排序时只要扫描到pos位置即可。
void bubble_sort(int arr[], int len)
{
    int j, k;
    int flag;


    flag = len;
    while (flag > 0)
    {
        k = flag;
        flag = 0;
        for (j = 1; j < k; j++)
            if (arr[j - 1] > arr[j])
            {
                std::swap(arr[j - 1], arr[j]);
                flag = j;
            }
    }
}
int main()
{
    int arr[]= {1,2,56,23,125,78,89,56,44,4,121,212,0,333};
    int length = sizeof(arr)/sizeof(arr[0]);
    bubble_sort(arr,length);
    printf("\n冒泡后:\t");
    for(int i = 0;i<length;i++){
        printf("%4d",arr[i]);
    }
    max_heapify(arr,length);
    printf("\n\n建堆后:\t");
    for(int i = 0;i<length;i++){
        printf("%4d",arr[i]);
    }
    printf("\n\n排序后:\t");


    heap_sort(arr,length);
    for(int i = 0;i<length;i++){
        printf("%4d",arr[i]);
    }
    printf("\n");
    return 0;
}
冒泡优化:https://github.com/7-sevens/algorithm/tree/master/sort


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值