A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

class ArrayDemo1
{
  public static void main(String[] args)
   {
     int[] arr={99,9,8,10,2,55,1};
     selectData2(arr,10);   //调用二分函数
   }

//找出指定的元素,二分查找
static void selectData2(int[]arr,int k)   //arr数组,k是要查找的元素
   {
/* 方法一:
    int min=0;// 首坐标
    int max=arr.length-1;// 尾坐标
    int mid;
        while(min<=max)  //如果终点坐标小于起点坐标,则未找到
          {
        mid=(min+max)/2; //中值坐标,取首尾之和/2,也可以用(向右移两位,相当于除2)
        if(k<arr[mid])
           max=mid-1;
          else if(k>arr[mid])
            min=mid+1;
         else
            {   System.out.println("数据查找成功!!"+"\t"+k+"在数组中的下标位置为:"+mid);
                return;
             }
        }
         System.out.println("数据查找失败!!");
*/
//第二种方法
int min=0;// 首坐标
    int max=arr.length-1;// 尾坐标
    int mid=(min+max)/2;
   while(k!=arr[mid])
  {
        if(k<arr[mid])
           max=mid-1;
         if(k>arr[mid])
            min=mid+1;
         if(max<min)
            {   System.out.println("数据查找失败!!");
                return;
             }
         mid=(min+max)/2;
        }
         System.out.println("数据查找成功!!"+"\t"+k+"在数组中的下标位置为:"+mid);
}

3 个回复

正序浏览
嗯,谢谢,知道了,视频没认真看。
回复 使用道具 举报
2分法查找的前提是数组要是有序数组
回复 使用道具 举报
有些值可以找到,有些值不可以,我觉得程序没问题啊
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马