二分查找算法-Java

本小妞迷上赌 提交于 2020-02-22 23:26:06
/**
 * @author cnkeysky
 */
public class DemoTest {

    public static void main(String[] args) {
        int[] arr = {1, 3, 10, 17, 20};
        int index = binarySearch(arr, 3);
        if (index < 0) {
            System.out.println("未查找到该数");
        } else {
            System.out.println("该数在数组中的下标为: " + index);
        }
    }

    public static int binarySearch(int[] arr, int value) {
        int len = arr.length;
        return binarySearch(arr, value, 0, len - 1);
    }

    public static int binarySearch(int[] arr, int value, int left, int right) {
        if (left > right) {
            return -1;
        }
        int mid = (right + left) / 2;
        if (arr[mid] == value) {
            return mid;
        } else if (arr[mid] < value) {
            return binarySearch(arr, value, mid + 1, right);
        } else {
            return binarySearch(arr, value, left, mid - 1);
        }
    }
    
}
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!