Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 306|回复: 0

[Java基础知识]你了解Arrays.binarySearch()方法的返回值吗?

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2014-9-30 17:42:34 | 显示全部楼层 |阅读模式
    今天遇到了一个关于Arrays.binarySearch()方法的返回值的问题:

    下面程序输出什么?

    import java.util.*;

    public class Quest {

    public static void main(String[] args) {

        String[] colors = {"blue","red","green","yellow","orange"};

        Arrays.sort(colors);

        System.out.println("after store: "+Arrays.toString(colors));

        int s2 = Arrays.binarySearch(colors, "orange");

        int s3 = Arrays.binarySearch(colors, "violet");

        System.out.println(s2+" "+s3);



         int[] Prime={3,5,7,11,17,23,31,37,43,47,67,79,89,97,137,163,179,197,277,311,331,

                      359,379,397,433,557,599,631,673,719};

         



         int k=Arrays.binarySearch(Prime,100);

          System.out.println(k);



         //在上面素数表中找一个最接近100的素数(大于),哈哈,只要这样做:

          System.out.println(Prime[-Arrays.binarySearch(Prime,100)-1]);

          

       }

    }



    正确的答案应该是

    2,-5

    -15

    137



    System.out.println("after store: "+Arrays.toString(colors));

    以后的输出是:

    [blue, green, orange, red, yellow]



    所以Arrays.binarySearch(colors, "orage"); 的结果应该是 2



    至于int s3 = Arrays.binarySearch(colors, "violet"); 为什么是-5,就要从Arrays.binarySearch() 讨论起了,如果找到了目标,

    Arrays.binarySearch() 产生的返回值就要大于或等于0。否则,它产生负返回值,表示若要保持数组的排序状态此元素所应该插入的 位置。这个负值的计算方式是:

       -(插入点)-1

       “插入点”是指,第一个大于查找对象的元素在数组中的位置,如果数组中所有的元素值都小于要查找的对象,“插入点”就等于



    Arrays.size()。




    二分查找返回负值的好处看看程序最后那一行就知道了.



    复制代码
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-5-20 17:03 , Processed in 0.352052 second(s), 47 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表