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

📄 hybridquicksortlistsorter.java

📁 BOOK:Beginning Algorithms Code Examples
💻 JAVA
字号:
package com.wrox.algorithms.sorting;import com.wrox.algorithms.lists.List;/** * Sample solution to exercise 7-5. * A {@link ListSorter} that uses an quicksort algorithm * with insertion sort for small sublists. * */public class HybridQuicksortListSorter implements ListSorter {    /** Size at which algorithm switches from insertion sort to quicksort. */    private static final int THRESHOLD = 5;    /** 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 HybridQuicksortListSorter(Comparator comparator) {        assert comparator != null : "comparator cannot be null";        _comparator = comparator;    }    /**     * Sorts a list using the quicksort algorithm.     *     * @param list The list to sort.     * @return the original List in sorted order.     */    public List sort(List list) {        assert list != null : "list cannot be null";        quicksort(list, 0, list.size() - 1);        return list;    }    private void quicksort(List list, int startIndex, int endIndex) {        if (startIndex < 0 || endIndex >= list.size()) {            return;        }        if (endIndex <= startIndex) {            return;        }        if (endIndex - startIndex < THRESHOLD) {            doInsertionSort(list, startIndex, endIndex);        } else {            doQuicksort(list, startIndex, endIndex);        }    }    private void doInsertionSort(List list, int startIndex, int endIndex) {        for (int i = startIndex + 1; i <= endIndex; ++i) {            Object value = list.get(i);            int j;            for (j = i; j > startIndex; --j) {                Object previousValue = list.get(j - 1);                if (_comparator.compare(value, previousValue) >= 0) {                    break;                }                list.set(j, previousValue);            }            list.set(j, value);        }    }    private void doQuicksort(List list, int startIndex, int endIndex) {        Object value = list.get(endIndex);        int partition = partition(list, value, startIndex, endIndex - 1);        if (_comparator.compare(list.get(partition), value) < 0) {            ++partition;        }        swap(list, partition, endIndex);        quicksort(list, startIndex, partition - 1);        quicksort(list, partition + 1, endIndex);    }    private int partition(List list, Object value, int leftIndex, int rightIndex) {        int left = leftIndex;        int right = rightIndex;        while (left < right) {            if (_comparator.compare(list.get(left), value) < 0) {                ++left;                continue;            }            if (_comparator.compare(list.get(right), value) >= 0) {                --right;                continue;            }            swap(list, left, right);            ++left;        }        return left;    }    private void swap(List list, int left, int right) {        if (left == right) {            return;        }        Object temp = list.get(left);        list.set(left, list.get(right));        list.set(right, temp);    }}

⌨️ 快捷键说明

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