排序算法——堆排序

什么是堆

堆就是一种特殊的二叉树,他有以下特点:

  • 堆中某个节点的值总是不大于或不小于其父节点的值;

  • 堆总是一棵完全二叉树。

堆又可以分为大根堆和小根堆

大根堆:根节点最大,每个节点都小于或等于父节点

小跟堆:根节点最小,每个节点都大于或等于父节点

堆的建立思想

以大根堆为例,每一个节点都当作是一个大根堆,我们通过维护每一个节点的堆结构进而将整个二叉树变成堆。由于叶子节点没有子节点,所有不需要对他维护。

代码实现

java 复制代码
//这里用数组来代替堆结构    
public void buildMapHeap(int []heap,int heapSize){
        //遍历没一个非叶子节点
        for(int i=(heapSize)/2-1;i>=0;i--){
            maxHeapify(heap,i,heapSize);
        }
    }

    public void maxHeapify(int []heap,int i,int heapSize){
        //左孩子索引
        int l=2*i+1;
        int r=2*i+2;
        //假设最大值的索引是父节点
        int maxVlue=i;
        if(l<heapSize&&heap[l]>heap[maxVlue]){ //(叶子节点不需要调整)&&()
            maxVlue=l;
        }
        if(r<heapSize&&heap[r]>heap[maxVlue]){ //(叶子节点不需要调整)&&()
            maxVlue=r;
        }
        if(maxVlue!=i){
            //交换让父节点值最大
            swap(heap,i,maxVlue);
            //由于调整的堆结构可能导致原来的子节点的堆结构发生改变
            //所有也要调整原来子节点的堆结构
            maxHeapify(heap,maxVlue,heapSize);
        }
    }
    public void swap(int heap[],int i,int j){
        int t=heap[i];
        heap[i]=heap[j];
        heap[j]=t;
    }

小根堆代码实现类似不在赘述 大家可以自己实现。

建立好大根堆后,堆顶就是数组里面最大的元素,如果要实现堆排序只需要每次移除这个堆顶元素,然后将堆尾元素替换,再重新以堆顶进行调整。

相关推荐
田里的水稻4 分钟前
C++_队列编码实例,从末端添加对象,同时把头部的对象剔除掉,中的队列长度为设置长度NUM_OBJ
java·c++·算法
纪元A梦12 分钟前
贪心算法应用:保险理赔调度问题详解
算法·贪心算法
Ripple123121 小时前
数据结构:顺序表与链表
数据结构·链表
Jayden_Ruan1 小时前
C++逆向输出一个字符串(三)
开发语言·c++·算法
一个响当当的名号2 小时前
B树,B+树,B*树(无代码)
数据结构·b树
点云SLAM2 小时前
C++ 常见面试题汇总
java·开发语言·c++·算法·面试·内存管理
叙白冲冲2 小时前
哈希算法以及面试答法
算法·面试·哈希算法
YuTaoShao3 小时前
【LeetCode 每日一题】1277. 统计全为 1 的正方形子矩阵
算法·leetcode·矩阵
古译汉书3 小时前
嵌入式铁头山羊stm32-ADC实现定时器触发的注入序列的单通道转换-Day26
开发语言·数据结构·stm32·单片机·嵌入式硬件·算法
野犬寒鸦3 小时前
力扣hot100:相交链表与反转链表详细思路讲解(160,206)
java·数据结构·后端·算法·leetcode