• 技术文章 >Java >java教程

    Java最小二叉树堆排序的实现方法

    黄舟黄舟2017-09-22 11:14:14原创1142
    这篇文章主要介绍了java 实现最小二叉树堆排序的实例的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下

    java 实现最小二叉堆排序的实例

    写在前面:

    一觉醒来,我就突然有灵感了......

    最小二叉堆定义:

    二叉堆是完全二元树或者是近似完全二元树,最小二叉堆是父结点的键值总是小于或等于任何一个子节点的键值的堆堆。

    存储:

    二叉堆一般用数组来表示。

    根节点在数组中的位置是0,第n个位置的子节点分别在2n+1和 2n+2;

    位置k的叶子的父节点位置为(k-1)/2;

    实现:


    /** 
     * @description 元素添加到末尾,和它的父节点比,如果比它小就交换 
     * @param array 
     * 
     * @author LynnWong 
     */ 
    private int[] getMinBinaryHeap(int[] array){ 
      int N = array.length; 
      int minBinaryHeap[] = new int[N]; 
      int root;//根的值 
      int heapSize = 0;//记录插入位置 
      for(int num : array){ 
        minBinaryHeap[heapSize]=num; 
        ++heapSize; 
        int pointer = heapSize-1;//当前指向的数组元素位置 
        while(pointer!=0){ 
          int leafPointer = pointer;//叶子节点位置 
          pointer = (pointer-1)/2;//根节点位置 
          root = minBinaryHeap[pointer];//根节点 
          if(num>=minBinaryHeap[pointer]){//永远把当前数组元素看成叶子与其根比较或者换位 
            break; 
          }//如果根比叶子大 就交换位置 
          minBinaryHeap[pointer] = num; 
          minBinaryHeap[leafPointer] = root; 
           
        } 
      } 
      return minBinaryHeap; 
       
    }


    /*** 
     * 用随机数测试二叉堆排序 
     * 测试10遍,强迫症似的变态... 
     */ 
    public void text(){ 
      for(int i=0;i<10;i++){ 
        Random rnd = new Random();  
        int [] lala = {rnd.nextInt(6),rnd.nextInt(6),rnd.nextInt(6),rnd.nextInt(6),rnd.nextInt(6),rnd.nextInt(6)}; 
        System.out.print("输入:"); 
        for(int a : lala){ 
          System.out.print(a+" "); 
        } 
        System.out.println(); 
        int []array = this.getMinBinaryHeap(lala); 
        System.out.print("输出:"); 
        for(int a : array){ 
          System.out.print(a+" "); 
        } 
        System.out.println(); 
      } 
    }

    以上就是Java最小二叉树堆排序的实现方法的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:Java 方法 实现
    上一篇:JAVA调用WCF服务的方法介绍 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • Java数据结构之单链表与OJ题• 一起来分析java设计模式之单例• 一文搞懂Java线程池实现原理• 详细介绍Java正则表达式之单字符匹配和预定义字符• Java总结分享之反射、枚举、Lambda表达式
    1/1

    PHP中文网