diff options
author | Mattias Andrée <maandree@operamail.com> | 2014-01-21 16:35:39 +0100 |
---|---|---|
committer | Mattias Andrée <maandree@operamail.com> | 2014-01-21 16:35:39 +0100 |
commit | 1d9332538db3c759b591f2bd0db43261dac03634 (patch) | |
tree | 564d137cbc1f4963975b55df6950020f5e0b6706 /src/algorithms/searching/BinarySearch.java | |
parent | compile with -Xlint:all,-cast (diff) | |
download | algorithms-and-data-structures-1d9332538db3c759b591f2bd0db43261dac03634.tar.gz algorithms-and-data-structures-1d9332538db3c759b591f2bd0db43261dac03634.tar.bz2 algorithms-and-data-structures-1d9332538db3c759b591f2bd0db43261dac03634.tar.xz |
partial array support in binary search + add multibinary search
Signed-off-by: Mattias Andrée <maandree@operamail.com>
Diffstat (limited to '')
-rw-r--r-- | src/algorithms/searching/BinarySearch.java | 78 |
1 files changed, 71 insertions, 7 deletions
diff --git a/src/algorithms/searching/BinarySearch.java b/src/algorithms/searching/BinarySearch.java index a72f75f..c4e35a7 100644 --- a/src/algorithms/searching/BinarySearch.java +++ b/src/algorithms/searching/BinarySearch.java @@ -113,7 +113,38 @@ public class BinarySearch */ public static £(fun "int" contains "${T} item, ${Tarray} array, SortOrder order") { - int low = £(cmp "array[0]" "item"); + return contains(item, array, order, 0, array.length£{Targ_name}); + } + + /** + * Gets whether an item may be contained by a list + * + * @param item The item for which to search + * @param array The list in which to search + * @param order The list's element order + * @param start The index of the first position to search in the array + * @return {@link #MAYBE}, {@link #TOO_SMALL}, {@link #TOO_LARGE}, {@link #EVERY_ELEMENT} + * or the index of a(!) found item [first or last position] + */ + public static £(fun "int" contains "${T} item, ${Tarray} array, SortOrder order, int start") + { + return contains(item, array, order, start, array.length£{Targ_name}); + } + + /** + * Gets whether an item may be contained by a list + * + * @param item The item for which to search + * @param array The list in which to search + * @param order The list's element order + * @param start The index of the first position to search in the array + * @param end The index after the last position to search in the array + * @return {@link #MAYBE}, {@link #TOO_SMALL}, {@link #TOO_LARGE}, {@link #EVERY_ELEMENT} + * or the index of a(!) found item [first or last position] + */ + public static £(fun "int" contains "${T} item, ${Tarray} array, SortOrder order, int start, int end") + { + int low = £(cmp "array[start]" "item"); if (order == SortOrder.ASCENDING) { @@ -123,20 +154,20 @@ public class BinarySearch int high = £(cmp "array[1]" "item"); if (low == 0) - return high == 0 ? EVERY_ELEMENT : 0; + return high == 0 ? EVERY_ELEMENT : start; - return high == 0 ? array.length - 1 : high < 0 ? TOO_LARGE : MAYBE; + return high == 0 ? end - 1 : high < 0 ? TOO_LARGE : MAYBE; } { if (low < 0) return TOO_SMALL; - int n = array.length - 1; + int n = end - 1; int high = £(cmp "array[n]" "item"); if (low == 0) - return high == 0 ? EVERY_ELEMENT : 0; + return high == 0 ? EVERY_ELEMENT : start; return high == 0 ? n : high > 0 ? TOO_LARGE : MAYBE; } @@ -155,10 +186,43 @@ public class BinarySearch */ public static £(fun "long" indexOf "${T} item, ${Tarray} array, SortOrder order, SearchMode mode") { + return indexOf(item, array, order, mode, 0, array.length£{Targ_name}); + } + + /** + * Finds the first, last or any occurance of an item in a list + * + * @param item The item for which to search + * @param array The list in which to search + * @param order The list's element order + * @param mode The search mode + * @param start The index of the first position to search in the array + * @return The index of the found item, if not mode does not say otherwise, or, if not + * found, the bitwise negation of the position to which it should be inserted + */ + public static £(fun "long" indexOf "${T} item, ${Tarray} array, SortOrder order, SearchMode mode, int start") + { + return indexOf(item, array, order, mode, start, array.length£{Targ_name}); + } + + /** + * Finds the first, last or any occurance of an item in a list + * + * @param item The item for which to search + * @param array The list in which to search + * @param order The list's element order + * @param mode The search mode + * @param start The index of the first position to search in the array + * @param end The index after the last position to search in the array + * @return The index of the found item, if not mode does not say otherwise, or, if not + * found, the bitwise negation of the position to which it should be inserted + */ + public static £(fun "long" indexOf "${T} item, ${Tarray} array, SortOrder order, SearchMode mode, int start, int end") + { £{Telement} x; - int min = 0, mid, rc = -1; - int max = array.length - 1; + int min = start, mid, rc = -1; + int max = end - 1; £>function f £>{ |