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

📄 recursivebinarylistsearcher.java

📁 BOOK:Beginning Algorithms Code Examples
💻 JAVA
字号:
package com.wrox.algorithms.bsearch;import com.wrox.algorithms.lists.List;import com.wrox.algorithms.sorting.Comparator;/** * A {@link ListSearcher} that uses recursion. * */public class RecursiveBinaryListSearcher implements ListSearcher {    /** The strategy to use for key comparison. */    private final Comparator _comparator;    /**     * Constructor.     *     * @param comparator The strategy to use for value comparison.     */    public RecursiveBinaryListSearcher(Comparator comparator) {        assert comparator != null : "comparator can't be null";        _comparator = comparator;    }    public int search(List list, Object value) {        assert list != null : "list can't be null";        return search(list, value, 0, list.size() - 1);    }    private int search(List list, Object value, int lowerIndex, int upperIndex) {        assert list != null : "list can't be null";        if (lowerIndex > upperIndex) {            return -(lowerIndex + 1);        }        int index = lowerIndex + (upperIndex - lowerIndex) / 2;        int cmp = _comparator.compare(value, list.get(index));        if (cmp < 0) {            index = search(list, value, lowerIndex, index - 1);        } else if (cmp > 0) {            index = search(list, value, index + 1, upperIndex);        }        return index;    }}

⌨️ 快捷键说明

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