[LinkedIn]Merge Sorted Iterator (using comparator)

原帖地址:http://www.mitbbs.com/article_t/JobHunting/32909075.html 自己加了一点注释

public static Iterable<Integer> mergeKSortedIterators(List<Iterator<Integer>> Iters){

        Queue<newIter> minHeap = new PriorityQueue<newIter>();
        List<Integer> result = new ArrayList<Integer>();
        for(Iterator<Integer> iter : Iters){
            if(iter.hasNext()){
                minHeap.add(new newIter(iter.next(), iter));
            }
        }

        while(!minHeap.isEmpty()){
            newIter newiter = minHeap.poll();
            result.add(newiter.getValue());
            if(newiter.hasNext()){
                minHeap.add(newiter);
            }
        }
        return result;
    }
    //这里存的是当前的value,因为直接compare哪个头最小的话,compare一次next()的值就没了,干脆直接用这个class来保存。
    //push的时候直接用里面的value来比较
    private static class newIter implements Comparable<newIter>{
        private Integer value;
        private Iterator<Integer> iter;
        public newIter(Integer val, Iterator<Integer> it){
            this.value = val;
            this.iter = it;
        }
        public Integer getValue(){
            return this.value;
        }
        public boolean hasNext(){
            if(iter.hasNext()){
                value = iter.next();
                return true;
            }
            return false;
        }

        public int compareTo(newIter a){
            return this.value - a.value;
        }
    }
posted on 2015-03-31 03:12  Seth_L  阅读(119)  评论(0编辑  收藏  举报