二分查找

二分查找(折半)

二分查找前提是必须是有序的

定义数组(有序)

折半比较

      将查找的元素和数组中间的元素比较,如果没找到则继续折半

 

二分查找法步骤(升序数组)

  1. 找到数组中间位置的值,并存放在一个top中
  2. 需要查找的值key,拿key和top比较
  3. 如果key>top,则把数组中间位置作为下一次计算的起点位置,重复(1)和(2)
  4. 如果key<top,则把数组中间位置作为下一次计算的终点位置,重复(1)和(2)和(3)
  5. 如果key=top,返回中间位置下标(元素),完成查找

 

 

 

 

示例:

package 二分;

 

public class 二分 {

   public static void main(String[] args) {

     int[] arr = { 1, 2, 3, 4, 5, 6, 7, 8, 9 };

     int searchNum = 8;// 要查找的数字

     int startIndex = 0;// 定义开始查找范围的下标

     int endIndex = arr.length - 1;// 定义结束查找范围的下标

     int midIndex = -1;// 定义中间位置的下标

     boolean isFind = false;// 标记是否找到,false没找到,true找到了

     do {

//中间的位置

        midIndex = (startIndex + endIndex) / 2;

        if (arr[midIndex] == searchNum) {

          System.out.println("恭喜您,找到了!下标是:" + midIndex);

          isFind = true;

          break;

        } else if (arr[midIndex] > searchNum) {

          endIndex = midIndex - 1;

        } else {

          startIndex = midIndex + 1;

        }

     } while (startIndex <= endIndex);

     if (! isFind) {

        System.out.println("抱歉,该数字没有找到");

     }

   }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值