大顶堆,小顶堆代码实现

只贴出代码参考,原理百度有很多讲解

大顶堆

 

 

public class LargeHeap {

    public static  void sort(Comparable[] a){
        for (int i = a.length/2-1; i >=0 ; i--) {
            adjustHeap(a,i,a.length-1);
        }
        建堆后 a[0]为最大值
        for (int i = a.length-1; i >0;i--) {
            //每次将堆顶和最后一个元素交换
            exch(a,0,i);
           //算法平均性能 nlogn
            //依次建堆n是for循环一层 logn 每次调整大顶堆 a[0]下沉 每次只比较交换 <logn
            adjustHeap(a,0,i-1);
        }
    }
    /*
    * 每次将数组lo...hi调整为大顶堆
    *
    * */
    public  static void adjustHeap(Comparable[] a,int lo,int hi){
         Comparable val=a[lo];
        //此处代码不难立即自己手动画图验证即可
        for (int i = lo*2+1; i <=hi ; i*=2) {
            if(i<hi&&less(a[i],a[i+1])) i++;
            if(!(less(val,a[i]))) break;
            a[lo]=a[i];lo=i;
        }
        a[lo]=val;
    }

    private  static  boolean less(Comparable v,Comparable w){
        return v.compareTo(w)<0;
    }

    private  static  void exch(Comparable[] a,int i,int j){
        Comparable t=a[i];a[i]=a[j];a[j]=t;
    }
    public  static boolean isSorted(Comparable[] a){
        for (int i = 0; i <a.length ; i++) {
            if(less(a[i],a[i])) return false;
        }
        return  true;
    }
    public  static  void main(String[] args){
        Comparable a[]={5,643,-1,53,4,1,2,97,88,9,0};
        sort(a);
        for (int i = 0; i < a.length; i++) {
            System.out.println(a[i]);
        }
    }
}

小顶堆

 

public class LittleHeap {
    public static  void sort(Comparable[] a){
        for (int i = a.length/2-1; i >=0 ; i--) {
            adjustHeap(a,i,a.length-1);
        }
        for (int i = a.length-1; i >0; i--) {
            exch(a,0,i);
            adjustHeap(a,0,i-1);
        }
    }
    /*
    * 每次将数组lo...hi调整为小顶堆 用到的方法是 堆的上浮算法
    *
    * */
    public  static void adjustHeap(Comparable[] a,int lo,int hi){
        Comparable val=a[lo];
        for (int i = lo*2+1; i <=hi ; i*=2) {
------------------------------这段代码是不同的-------------------------
---------------------------------------------------------------------
            /*检查边界 i=hi-1时候保证i+1 存在 */
            if(i<hi&&less(a[i+1],a[i])) i++;
            /*如果不经过上一步就直接和当前节点子节点比对(此时只有一个节点)*/
            if(less(a[i],val)){
                a[lo]=a[i];lo=i;
            }else break;
--------------------------------------------------------------------------
        }
        a[lo]=val;
    }

    private  static  boolean less(Comparable v,Comparable w){
        return v.compareTo(w)<0;
    }
    private  static  void exch(Comparable[] a,int i,int j){
        Comparable t=a[i];a[i]=a[j];a[j]=t;
    }
    public  static boolean isSorted(Comparable[] a){
        for (int i = 0; i <a.length ; i++) {
            if(less(a[i],a[i])) return false;
        }
        return  true;
    }
    public  static  void main(String[] args){
        Comparable a[]={5,643,53,4,1,2,97,88,9,0};
        sort(a);
        for (int i = a.length-1; i >=0; i--) {
            System.out.println(a[i]);
        }
    }



}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值