liupete 2012-04-28 09:18
浏览 343
已采纳

关于Collections.binarySearch的问题

我在测试写Collections.binarySearch发现以下的问题,大哥们能不能帮我解惑下:
public static void main(String[] args) {
List all = new ArrayList();
Collections.addAll(all, "ww","wh","gh","dr");
System.out.println(all);
int point = Collections.binarySearch(all,"ww");
System.out.println(pu);
}
这是我测试的代码,发现一个问题,这样是其中有两个内容出现重复现象,那么查询到的point就是负数,比如我添加的元素有hh,hw.那么查询hh的话,会是负数,查询hw就不会.疑惑中。

  • 写回答

3条回答 默认 最新

  • iDeputy 2012-04-28 09:31
    关注

    调用binarySearch之前, 需对列表进行升序排序sort(all)。如果没有对列表进行排序,则结果是不明确的。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥50 永磁型步进电机PID算法
  • ¥15 sqlite 附加(attach database)加密数据库时,返回26是什么原因呢?
  • ¥88 找成都本地经验丰富懂小程序开发的技术大咖
  • ¥15 如何处理复杂数据表格的除法运算
  • ¥15 如何用stc8h1k08的片子做485数据透传的功能?(关键词-串口)
  • ¥15 有兄弟姐妹会用word插图功能制作类似citespace的图片吗?
  • ¥200 uniapp长期运行卡死问题解决
  • ¥15 latex怎么处理论文引理引用参考文献
  • ¥15 请教:如何用postman调用本地虚拟机区块链接上的合约?
  • ¥15 为什么使用javacv转封装rtsp为rtmp时出现如下问题:[h264 @ 000000004faf7500]no frame?