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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 北风 中级黑马   /  2014-9-27 21:11  /  1333 人查看  /  5 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 北风 于 2014-9-27 22:19 编辑

    楼主开始看毕老师的视频了,可能是刚开始热情高涨的原因。今天一天看了50多段了已经。就在刚刚,看到了数组中的折半查找方法的讲解视频。
    在视频中,毕老师说了一个面试练习题:有一个有序的数组,将某元素插入到该数组中,要保证插入后的数组是有序的,问该插在数组的哪个位置?
    可能是听了一天的视频,大脑有点疲惫的原因。听懂了老毕讲的折半查找的方法,但是对于这个练习题中折半查找方法的延伸。。还是有点不太懂 。。为什么会返回min呢,我的疑问是因为在查找时有两个移动的下边界min和上边界max,能用max来作为要插入的数组位置返回吗?如果不能,想问,为什么?谢谢,希望大家解惑。
  1. public static int halfSearch_2(int [] arr, int key){
  2.                 int min = 0, max = arr.length-1, mid;
  3.                 while (min<=max) {
  4.                         mid = (max+min)>>1;  //位运算右移一位
  5.                         if(key>arr[mid])
  6.                                 min = mid + 1;
  7.                         else if(key<arr[mid])
  8.                                 max = mid -1 ;
  9.                         else
  10.                                 return mid;             //返回值       
  11.                 }
  12.                 return -1 ;   //帖子中的联系题的代码就是将该句代码改为了 return min;
  13.         }
复制代码

注:return -1 ; //帖子中的联系题的代码就是将该句代码改为了 return min;

5 个回复

倒序浏览
不会问问题,连代码都没有
回复 使用道具 举报
cs8630323 发表于 2014-9-27 21:53
不会问问题,连代码都没有

代码已贴,求解决:P
回复 使用道具 举报
我不知道这两个步奏,你有没有看懂,这个例子能够返回min值得原因,就是到最后min的值比max要大,所以只能返回min的值,反之,如果要是返回max的值,那最后的结果跟实际是相差的。

20140927223550.png (61.59 KB, 下载次数: 9)

20140927223550.png

QQ截图20140927224617.png (26.3 KB, 下载次数: 4)

QQ截图20140927224617.png
回复 使用道具 举报
CC_gogo 发表于 2014-9-27 22:52
我不知道这两个步奏,你有没有看懂,这个例子能够返回min值得原因,就是到最后min的值比max要大,所以只能 ...

按着您说的,今天连续看了三遍视频。现在懂了。非常感谢。
回复 使用道具 举报
北风 发表于 2014-9-28 11:41
按着您说的,今天连续看了三遍视频。现在懂了。非常感谢。

嗯嗯,我也是看视频有时候反复看,才能看懂。
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马