二分法查询元素下标

在这里插入图片描述

public class ArrayUtil {
    public static void main(String[] args) {
        //这是int类型数组的对象
        int[] arr = {9, 8, 10, 7, 6, 87, 11};
        //找出arr这个数组中87所在下标
        //调用方法
        int index = binarySearch(arr, 87);
        System.out.println(index == -1 ? "该元素不存在" : "该元素的下标" + index);

    }

    /**
     * 从数组中查找目标元素的下标
     * @param arr被查找的s数组(已经排序的)
     * @param dest目标元素
     * @return -1不存在,其他表示返回的是元素的下标
     */
    private static int binarySearch(int[] arr, int dest) {
        //开始下标
        int begin=0;
        //结束下标
        int end = arr.length - 1;
        //开始元素的下标只要在结束元素下标的左边,就有机会继续循环
        while (begin <= end) {
            //中间元素下标
            int mid = (begin + end) / 2;
            if (arr[mid] == dest) {
                return mid;
            } else if (arr[mid] < dest) {
                //目标在“中间的”右边
                //开始元素下标需要发生变化,(开始元素的下标需要重新赋值)
                begin = mid + 1;//一直增
            } else {
                //arr[mid]>dest
                //目标在“中间”左边
                //修改结束元素的下标
                end = mid - 1;
            }
        }
            return -1;
        }
    }


结果

该元素的下标5
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值