zoukankan      html  css  js  c++  java
  • 优先队列代码实现

    import java.util.Arrays;
    
    /**
     * 时间复杂度 logn
     * @author liyhu
     *
     */
    public class PriorityQueue {
    
        private int[] array;
        private int size;
        public PriorityQueue() {
            super();
            array=new int[32];
        }
        /**
         * 
         * @Description: (入队) 
         * @author: liyhui
         * @date: 2018年11月24日
         * @param key
         */
        private void enQueue(int key) {
            //队列长度超出范围,扩容
            if(size >= array.length) {
                resize();
            }
            array[size++]=key;
            upAdjust();
        }
        /**
         * 
         * @Description: (出队) 
         * @author: liyhui
         * @date: 2018年11月24日
         * @return
         */
        private int deQueue() {
            if(size < 0) {
                throw new RuntimeException("the queue is empty");
            }
            //获取堆顶元素
            int head=array[0];
            //最后一个元素移动到堆顶
            array[0]=array[--size];
            downAdjust();
            return head;
        }
        /**
         * 
         * @Description: (下沉) 
         * @author: liyhui
         * @date: 2018年11月24日
         */
        private void downAdjust() {
            int parentIndex=0;
            //temp 保存插入的父节点值,用于最后赋值
            int temp=array[parentIndex];
            int childIndex=1;
            while(childIndex < size) {
                //如果有右孩子,且右孩子大于左孩子的值,则定位到右孩子
                if(childIndex +1 < size && array[childIndex+1] > array[childIndex] ) {
                    childIndex++;
                }
                //如果父节点大于任何一个孩子的值,直接跳出
                if(temp > array[childIndex]) {
                    break;
                }
                //无需真正交换,单向赋值即可、
                array[parentIndex]=array[childIndex];
                parentIndex=childIndex;
                childIndex= childIndex << 1 + 1;
            }
            array[parentIndex]=temp;
        }
        /**
         * 
         * @Description: (上浮) 
         * @author: liyhui
         * @date: 2018年11月24日
         */
        private void upAdjust() {
            int childIndex=size-1;
            int parentIndex=childIndex/2;
            //temp 保存插入的叶子节点值,用于最后赋值
            int temp=array[childIndex];
            while(childIndex > 0 && temp > array[parentIndex]) {
                //无需真正交换,单向赋值即可
                array[childIndex]=array[parentIndex];
                childIndex=parentIndex;
                parentIndex=parentIndex >> 1;
            }
            array[childIndex]=temp;
        }
        /**
         * 
         * @Description: (扩容) 
         * @author: liyhui
         * @date: 2018年11月24日
         */
        private void resize() {
            // 队列容量翻倍
            int newSize=this.size << 1;
            this.array=Arrays.copyOf(this.array, newSize);        
        }
        public static void main(String[] args) {
            
            PriorityQueue queue=new PriorityQueue();
            queue.enQueue(3);
            queue.enQueue(5);
            queue.enQueue(10);
            queue.enQueue(2);
            queue.enQueue(7);
            System.out.println("出队元素:"+queue.deQueue());
            System.out.println("出队元素:"+queue.deQueue());
        }
        
    }

     最大堆的实现

  • 相关阅读:
    通过Vim+少量插件配置一个高效简洁的IDE
    Javascript中Closure及其相关概念
    MongoDB对Javascript的支持
    正则表达式中分组功能高级用法
    NAT穿透解决方案介绍
    平衡二叉树算法分析
    字符串匹配KMP算法详解
    node 内存溢出
    React项目编译node内存溢出
    正则表达正整数/正则表达正整数不包括0
  • 原文地址:https://www.cnblogs.com/dongma/p/10012661.html
Copyright © 2011-2022 走看看