首页 > 其他 > 详细

二分查找

时间:2015-11-04 00:23:59      阅读:260      评论:0      收藏:0      [点我收藏+]
/**
 * Created by icecookstar on 2015/11/3.
 */
public class BinarySearch {

    private static int binarySearch(int[] matrix, int i, int j, int find) {
        if (i > j) {
            return -1;
        }
        int middle = (i + j) / 2;

        if (matrix[middle] == find) {
            return middle;
        } else if (matrix[middle] < find) {
            return binarySearch(matrix, middle + 1, j, find);
        } else {
            return binarySearch(matrix, i, middle - 1, find);
        }
    }

    private static int binarySearch(int[] matrix, int find) {
        int start = 0;
        int end = matrix.length - 1;
            while (start <= end) {
            int middle = (start + end) / 2;

            if (matrix[middle] == find) {
                return middle;
            } else if (matrix[middle] < find) {
                start = middle + 1;
            } else {
                end = middle - 1;
            }
        }
        return -1;
    }

    public static void main(String[] args) {
        int[] matrix = new int[]{2, 4, 6, 7, 8, 10};
        System.out.print(binarySearch(matrix, 0, matrix.length - 1, 4));
        System.out.print(binarySearch(matrix, 2));
    }
}

 

二分查找

原文:http://www.cnblogs.com/duanxingxing/p/4934611.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!