码迷,mamicode.com
首页 > 编程语言 > 详细

二分查找算法(非递归)

时间:2019-09-30 14:56:35      阅读:84      评论:0      收藏:0      [点我收藏+]

标签:turn   print   search   二分查找算法   ret   ==   递归   string   目标   

    /**
     * @param data   带查找的数组(数组)
     * @param target 目标数据
     * @return 返回对应的下标,-1 表示没有找到
     */
    public static int binarySearch(int[] data, int target) {
        int low = 0;
        int high = data.length - 1;
        // 继续查找
        while (high >= low) {
            int mid = (low + high) / 2;
            if (data[mid] == target) {
                return mid;
                // 向左边查找
            } else if (data[mid] > target) {
                high = mid - 1;
                //向右边查找
            } else if (data[mid] < target) {
                low = mid + 1;
            }
        }

        return -1;

    }

    public static void main(String[] args) {
        int[] data = {1,6,8,41,68,100};
        System.out.println(binarySearch(data, 100));
    }

二分查找算法(非递归)

标签:turn   print   search   二分查找算法   ret   ==   递归   string   目标   

原文地址:https://www.cnblogs.com/MND1024/p/11611682.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!