⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 iterativemergesortlistsorter.java

📁 BOOK:Beginning Algorithms Code Examples
💻 JAVA
字号:
package com.wrox.algorithms.sorting;import com.wrox.algorithms.iteration.Iterator;import com.wrox.algorithms.lists.ArrayList;import com.wrox.algorithms.lists.List;/** * Sample solution for exercise 7-1. * Iterative implementation of mergesort algorithm. * */public class IterativeMergesortListSorter implements ListSorter {    /** The comparator to control the order of the sorted objects. */    private final Comparator _comparator;    /**     * @param comparator the comparator to control the order of the sorted objects.     */    public IterativeMergesortListSorter(Comparator comparator) {        assert comparator != null : "comparator cannot be null";        _comparator = comparator;    }    /**     * Sorts a list using the mergesort algorithm.     *     * @param list The list to sort.     * @return A new List containing the items from the original List in sorted order.     */    public List sort(List list) {        assert list != null : "list cannot be null";        return mergeSublists(createSublists(list));    }    private List mergeSublists(List sublists) {        List remaining = sublists;        while (remaining.size() > 1) {            remaining = mergeSublistPairs(remaining);        }        return (List) remaining.get(0);    }    private List mergeSublistPairs(List remaining) {        List result = new ArrayList(remaining.size() / 2 + 1);        Iterator i = remaining.iterator();        i.first();        while (!i.isDone()) {            List left = (List) i.current();            i.next();            if (i.isDone()) {                result.add(left);            } else {                List right = (List) i.current();                i.next();                result.add(merge(left, right));            }        }        return result;    }    private List createSublists(List list) {        List result = new ArrayList(list.size());        Iterator i = list.iterator();        i.first();        while (!i.isDone()) {            List singletonList = new ArrayList(1);            singletonList.add(i.current());            result.add(singletonList);            i.next();        }        return  result;    }    private List merge(List left, List right) {        List result = new ArrayList();        Iterator l = left.iterator();        Iterator r = right.iterator();        l.first();        r.first();        while (!(l.isDone() && r.isDone())) {            if (l.isDone()) {                result.add(r.current());                r.next();            } else if (r.isDone()) {                result.add(l.current());                l.next();            } else if (_comparator.compare(l.current(), r.current()) <= 0) {                result.add(l.current());                l.next();            } else {                result.add(r.current());                r.next();            }        }        return result;    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -