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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 杨冬冬 中级黑马   /  2014-7-11 23:57  /  1214 人查看  /  9 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 杨冬冬 于 2014-7-13 22:37 编辑

今天遇到一个问题是关于二分查找的问题,是求一个元素在集合中的索引值问题。代码如下


他的结果是2,-4而37根本就不存在,索引值却显示-4,为什么

123.jpg (205.2 KB, 下载次数: 5)

123.jpg

9 个回复

倒序浏览
很深入,,学习 一下。
回复 使用道具 举报
返回-4有两个含义:
1.负数表示元素在集合中不存在;
2.如果要把查找的元素添加到集合中,该位置的角标就为:4-1=3.
回复 使用道具 举报
首先:你排序了吗?不排序怎么用二分查找...
如果按10,20,30,40,50排好序
37应该返回-4
即当找到第3个索引位置(即40)仍没找到,但40已经大于37了,就返回40的索引加上1,取负,即-4
同理,找100,应返回-6,即找到第5索引仍没找到该元素,返回5加上1,取负
回复 使用道具 举报
楼上正解。
回复 使用道具 举报
二分查找前提是有序啊.
回复 使用道具 举报
yangcy 中级黑马 2014-7-12 08:54:55
7#
曲佳奇 发表于 2014-7-12 08:09
二分查找前提是有序啊.

正解。。。。。
回复 使用道具 举报
哦,我错了,我把中间那个排序的代码删了。
回复 使用道具 举报
ahuhxl 中级黑马 2014-7-14 08:19:42
9#
若查找的值不存在,返回值是(-插入点-1)
回复 使用道具 举报
谢谢各位同学的帮忙,这个问题,我看Java的源代码已经搞明白了
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马