<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-153  評(píng)論-235  文章-19  trackbacks-0
        java庫里的PriorityQueue無法滿足我,它不能固定容量,不遍歷(遍歷后就無序了),它的排序因字是從小到大(雖然可以用Comparator來反轉(zhuǎn)大小順序)。我所要的是可以固定容量(在一大堆數(shù)據(jù)通信中選擇最大或最小的幾個(gè)數(shù)時(shí)很有用),可遍歷(不是一個(gè)個(gè)poll())。
        于是,在有空的時(shí)間里寫了一下。內(nèi)容是一個(gè)雙向鏈表(帶頭的,頭不作保存數(shù)據(jù)),用插入排序。個(gè)人認(rèn)為一個(gè)個(gè)添加的用插入排序效果比較好。從隊(duì)尾到隊(duì)頭找合適的插入位置,是穩(wěn)定的排序。
        添加的實(shí)體可以用Comparator或Comparable,如果這兩個(gè)都不是,就失去排序的效果。實(shí)現(xiàn)了比較高興,發(fā)表下,讓大家找出bug

    package net.blogjava.chenlb.util;

    import java.util.AbstractQueue;
    import java.util.Comparator;
    import java.util.Iterator;

    /**
     * 
    @param <E>
     * 容量capacity大于0,最多只能添加capacity個(gè),多出的被刪除掉.<br/>
     * 刪除時(shí)根據(jù){
    @link Comparable}或{@link Comparator} 和 desc
     * 如果comparator==null時(shí)使用Comparable<br/>
     * non-thread safe
     * 
    @author chenlb 2008-4-23 下午11:31:06
     
    */
    public class TopPriorityQueue<E> extends AbstractQueue<E> implements java.io.Serializable {

        
    private static final long serialVersionUID = 1L;

        
    private int size;
        
    private LinkedItem head;
        
    private LinkedItem last;
        
    private int top;    //top>0后,容量有限制
        private Comparator<? super E> comparator;
        
    private boolean desc;    //降序
        
        
    /**
         * 容量無限制,升序.
         
    */
        
    public TopPriorityQueue() {
            
    this(0nullfalse);
        }
        
        
    /**
         * 容量無限制,
         * 
    @param desc true為降序.
         
    */
        
    public TopPriorityQueue(boolean desc) {
            
    this(0null, desc);
        }

        
    /**
         * 容量無限制,升序,用comparator排序
         
    */
        
    public TopPriorityQueue(Comparator<? super E> comparator) {
            
    this(0, comparator, false);
        }
        
        
    /**
         * 容量無限制,用comparator排序
         * 
    @param desc true為降序
         
    */
        
    public TopPriorityQueue(Comparator<? super E> comparator, boolean desc) {
            
    this(0, comparator, desc);
        }
        

        
    /**
         * 容量限制為capacity.超出容量限制的,會(huì)刪除優(yōu)先級(jí)最小(隊(duì)尾).
         
    */
        
    public TopPriorityQueue(int capacity) {
            
    this(capacity, nullfalse);
        }
        
        
    public TopPriorityQueue(int capacity, boolean desc) {
            
    this(capacity, null, desc);
        }
        
        
    public TopPriorityQueue(int capacity, Comparator<? super E> comparator) {
            
    this(capacity, comparator, false);
        }
        
        
    public TopPriorityQueue(int capacity, Comparator<? super E> comparator, boolean desc) {
            head 
    = new LinkedItem();
            last 
    = head;
            top 
    = capacity;
            
    this.comparator = comparator;
            
    this.desc = desc;
        }
        @Override
        
    public Iterator<E> iterator() {
            
    // TODO 迭代器
            return new It(head);
        }

        @Override
        
    public int size() {
            
    return size;
        }

        
        
    public boolean offer(E o) {
            
    // TODO 添加到適當(dāng)?shù)奈恢?/span>
            if(o == null) {
                
    throw new IllegalArgumentException("不能添加值為null的!");
            }
            LinkedItem temp 
    = new LinkedItem(o);
            
    /*last.next = temp;
            temp.prev = last;
    */
            
    if(last == head) {    //第一個(gè)
                last.next = temp;
                temp.prev 
    = last;
                
                last 
    = temp;
            } 
    else {
                LinkedItem tempPrev 
    = last;
                
    if(comparator != null) {
                    
    while(tempPrev!=null && tempPrev != head) {
                    
                        
    int r = comparator.compare(tempPrev.data, temp.data);
                        
    if(desc) {
                            r 
    = 0 - r;
                        }
                        
    if(r == 1) {    //tempPrev > temp
                            
    //重置,繼續(xù)向前找
                            tempPrev = tempPrev.prev;
                        } 
    else {    //找到插入的位置
                            break;
                        }
                    }
                    
                } 
    else if(o instanceof Comparable) {    //用Comparable
                    
                    
    while(tempPrev!=null && tempPrev != head) {
                        Comparable
    <E> tPrev = (Comparable<E>) tempPrev.data;
                        
    int r = tPrev.compareTo(temp.data);
                        
    if(desc) {
                            r 
    = 0 - r;
                        }
                        
    if(r == 1) {    //tempPrev > temp
                            
    //重置,繼續(xù)向前找
                            tempPrev = tempPrev.prev;
                        } 
    else {    //找到插入的位置
                            break;
                        }
                    }
                }
                
    if(tempPrev != null) {    //插入
                    if(tempPrev == last) {    //后面添加的
                        last = temp;
                    }
                    
                    temp.next 
    = tempPrev.next;
                    
    if(tempPrev.next != null) {
                        tempPrev.next.prev 
    = temp;
                    }
                    tempPrev.next 
    = temp;
                    temp.prev 
    = tempPrev;
                }
            }
            
            size
    ++;
            
    if(top > 0 && size > top) {    //去掉優(yōu)先級(jí)最小的
                tail();
            }
            
    return true;
        }

        
    /**
         * 從棧底去除
         
    */
        
    public E tail() {
            
    if(last == head) {
                
    return null;
            }
            LinkedItem laster 
    = last;
            last 
    = last.prev;
            last.next 
    = null;
            laster.prev 
    = null;
            size
    --;
            
    return laster.data;
        }
        
        
    public E peek() {
            
    // TODO 取得棧頂值
            LinkedItem first = head.next;
            
    if(first != null) {
                
    return first.data;
            }
            
    return null;
        }

        
        
    public E poll() {
            
    // TODO 從棧頂去除
            LinkedItem first = head.next;
            
    if(first != null) {
                head.next 
    = first.next;
                
    if(first.next != null) {
                    first.next.prev 
    = head;
                }
                size
    --;
                
    return first.data;
            }
            
    return null;
        }

        
    private class It implements Iterator<E> {

            LinkedItem curr;
            
            
    public It(LinkedItem curr) {
                
    super();
                
    this.curr = curr;
            }

            
            
    public boolean hasNext() {
                
    if(curr != null && curr.next != null) {
                    
    return true;
                }
                
    return false;
            }

            
            
    public E next() {
                curr 
    = curr.next;
                E d 
    = curr.data;
                
    return d;
            }

            
            
    public void remove() {
                curr.prev.next 
    = curr.next;
                
    if(curr.next != null) {
                    curr.next.prev 
    = curr.prev;
                }
                size
    --;
            }
            
        }
        
        
    /**
         * 
    @param <E>
         * 鏈結(jié)點(diǎn).
         * 
    @author chenlb 2008-5-4 下午04:48:17
         
    */
        
    private class LinkedItem {
            LinkedItem prev;
            E data;
            LinkedItem next;
            
    public LinkedItem() {
            }
            
    public LinkedItem(E o) {
                
    this.data = o;
            }
        }
    }
    posted on 2008-05-08 23:08 流浪汗 閱讀(1011) 評(píng)論(0)  編輯  收藏 所屬分類: JAVA/J2EE
    主站蜘蛛池模板: 亚洲国产综合人成综合网站00| 亚洲日本乱码卡2卡3卡新区| 国产高清在线精品免费软件| 野花高清在线观看免费3中文| 国产精品亚洲а∨天堂2021| 亚洲精品中文字幕无码A片老| 国产中文在线亚洲精品官网| 四虎在线播放免费永久视频| 国产乱子伦精品免费女| 国产中文字幕免费观看| 免费二级毛片免费完整视频| 免费国产在线观看不卡| 亚洲天堂中文字幕在线| 亚洲人成无码网站| 亚洲αv在线精品糸列| 久久精品a亚洲国产v高清不卡| 亚洲国产精品13p| 免费大学生国产在线观看p| 亚洲乱亚洲乱少妇无码| 亚洲乱码日产一区三区| 亚洲午夜精品一区二区| 亚洲AV无码专区在线亚| 校园亚洲春色另类小说合集 | 在线免费播放一级毛片| 最新亚洲成av人免费看| 午夜免费啪视频在线观看| 国产成人精品免费午夜app| 青青草a免费线观a| 国产网站免费观看| 国产亚洲精品无码专区| 久久久婷婷五月亚洲97号色| 亚洲一区在线视频| 麻豆一区二区三区蜜桃免费| 中文字幕免费视频精品一| 久久综合给合久久国产免费| 免费A级毛片无码免费视| 无码欧精品亚洲日韩一区夜夜嗨| 成年女人男人免费视频播放| 免费夜色污私人影院在线观看| 一二三四影视在线看片免费| 免费无遮挡无码视频网站|