for if 2022-08-18 16:49 采纳率: 100%
浏览 46
已结题

这种算法可以算是二分查找吗

java编写二分查找算法

这种算法可以算是二分查找吗,和其他的人的思路并不相同,但是功能可以实现。

public static int binarySearch(int[] arr,int value){

    for (int i = 0; i < arr.length; i++) {

        /**
         * 循环的次数
         */
        System.out.println("算法1循环的次数"+i);

        int a = arr[i];

        int endIndex = arr.length-1-i;
        int end = arr[endIndex];

        if(a == value){
            return i;
        }else if(end == value){
            return  arr.length-1-i;
        }
    }
    return -1;
}
  • 写回答

4条回答 默认 最新

  • 林夕07 2022-08-18 16:53
    关注

    不算。二分的思想在于每次数据量都少一半。你这里的就是从头遍历罢了,你难道没发现你的endIndex不会变化吗?你每次相当于那第i个元素和最后一个元素去和你的vaue去比较。
    你可以参考一下下面C语言的二分写法

    int binary_search(int* n, int len, int key)
    {
    
        int start = 0;
        int end = len - 1;
        int mid = 0;
        while (start <= end)
        {
            mid = (end - start) / 2 + start;
            if (n[mid] < key)
            {
    
                start = mid + 1;
            }
            else if (n[mid] > key)
            {
    
                end = mid - 1;
            }
            else //相等 
            {
                return mid;
            }
        }
        return -1;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 8月26日
  • 已采纳回答 8月18日
  • 创建了问题 8月18日

悬赏问题

  • ¥15 微信会员卡接入微信支付商户号收款
  • ¥15 如何获取烟草零售终端数据
  • ¥15 数学建模招标中位数问题
  • ¥15 phython路径名过长报错 不知道什么问题
  • ¥15 深度学习中模型转换该怎么实现
  • ¥15 HLs设计手写数字识别程序编译通不过
  • ¥15 Stata外部命令安装问题求帮助!
  • ¥15 从键盘随机输入A-H中的一串字符串,用七段数码管方法进行绘制。提交代码及运行截图。
  • ¥15 TYPCE母转母,插入认方向
  • ¥15 如何用python向钉钉机器人发送可以放大的图片?