📄 iterativemergesortlistsorter.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 + -