二进制搜索整数数组
/* * Copyright (c) 2013 Menny Even-Danan * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ import java.lang.reflect.Method; import java.util.Arrays; // 来自 时 代 J a v a public class Main{ public static void main(String[] argv) throws Exception{ int[] array = new int[]{34,35,36,37,37,37,67,68,69}; int startIndex = 2; int endIndex = 2; int value = 2; System.out.println(binarySearch(array,startIndex,endIndex,value)); } private static final Method METHOD_Arrays_binarySearch = CompatUtils .getMethod(Arrays.class, "binarySearch", int[].class, int.class, int.class, int.class); public static int binarySearch(int[] array, int startIndex, int endIndex, int value) { if (METHOD_Arrays_binarySearch != null) { final Object index = CompatUtils.invoke(null, 0, METHOD_Arrays_binarySearch, array, startIndex, endIndex, value);/*时 代 J a v a 公 众 号 - nowjava.com 提 供*/ return (Integer) index; } else { return compatBinarySearch(array, startIndex, endIndex, value); } } static int compatBinarySearch(int[] array, int startIndex, int endIndex, int value) { if (startIndex > endIndex) throw new IllegalArgumentException(); if (startIndex < 0 || endIndex > array.length) throw new ArrayIndexOutOfBoundsException();