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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

请看代码:
import java.util.*;
class CollectionsDemo3
{
        public static void main(String[] args)
        {
                binarySearchDemo();
        }
        public static void sop(Object obj)
        {
                System.out.println(obj);
        }
        public static void binarySearchDemo()
        {
                List<String> list=new ArrayList<String>();
                list.add("acv");
                list.add("bsd");
                list.add("kjdaaa");
                list.add("qq");
                list.add("x");
                list.add("qq");
                Collections.sort(list);
                sop(list);
                int index=Collections.binarySearch(list,"fgh");
                sop("index="+index);//打印结果:-3   集合中没找到"fgh"元素,为什么返回-3?不返回-1呢?
        }
}

4 个回复

正序浏览
int indexedBinarySearch(List<? extends Comparable<? super T>> list, T key)
    {
        int low = 0;
        int high = list.size()-1;

        while (low <= high) {
            int mid = (low + high) >>> 1;
            Comparable<? super T> midVal = list.get(mid);
            int cmp = midVal.compareTo(key);

            if (cmp < 0)
                low = mid + 1;
            else if (cmp > 0)
                high = mid - 1;
            else
                return mid; // key found
        }
        return -(low + 1);  // key not found
    }
在进入while时low变成了2
回复 使用道具 举报
  以后遇到这种情况 建议你看一下api   里面介绍的很清楚的  
   我们不可能把每个方法的返回类型和怎么返回的 都记清楚   也不太现实  所以查api是个好习惯啊  亲
如果搜索键包含在列表中,则返回搜索键的索引;否则返回 (-(插入点) - 1)。插入点 被定义为将键插入列表的那一点:即第一个大于此键的元素索引;如果列表中的所有元素都小于指定的键,则为 list.size()。注意,这保证了当且仅当此键被找到时,返回的值将 >= 0。
      插入点就是说 你要查找的那个字符串没有  但是他的大小刚好排在你的集合中的2角标哪   -2-1 就是-3  你可以试一试  查一个没有的字符串  但是这个字符串是最小的 他就返回-1 了
回复 使用道具 举报
多打了个否。。。。。
就是 -(插入点)  再-1 一次  你算一下就 能理解的
回复 使用道具 举报
int index=Collections.binarySearch(list,"fgh");
返回的是fgh 的角标位,如果没有该元素否则返回 (-(插入点) - 1)。
  你算一下 该集合中没有fgh的元素,然后会直接返回它的插入点  应该是 2  然后  -2-1 =-3  所以返回 -3  
能理解吗?
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马