java中binarysearch是什么_[转载] Java 中的binarySearch方法

本文介绍了Java中Collections工具类的binarySearch方法,用于在排序后的List集合中通过二分搜索法查找元素。文章强调了列表必须先排序且排序规则与binarySearch方法一致才能得到正确索引。示例展示了升序和自定义排序规则下binarySearch的使用,并给出了相应的代码实现和结果分析。
摘要由CSDN通过智能技术生成

参考链接: Java中的二分搜索binarySearch

Java提供了一个操作Set 、 List和Map等集合的工具类:Collections,该工具类里提供了大量方法对集合元素进行排序、查询和修改等操作,下面要说的就是查询操作中的binarySearch方法。

首先创建一个list集合,代码如下:

List list = new ArrayList<>();

list.add(6);

list.add(1);

list.add(5);

list.add(3);

list.add(4);

list.add(2);

System.out.println(list);

输出结果如图:

1、binarySearch(List list, T key):使用二分搜索法搜索指定列表,第一个参数是列表,第二个参数是要查找的元素,返回的是要查找的元素的索引。只有排序后的List集合才可用二分法查询元素的索引,而且List集合的排序(升序或降序)要和binarySearch的排序(升序或降序)一致,不然返回的索引不准确。

例如:直接对这个列表使用binarySearch方法,查找元素3在这个集合中的索引位置。代码如下:

int intA = Collections.binarySearch(list, 3);

System.out.println("list集合:" + list);

System.out.println("3在集合中的索引位置:" + intA);

返回的索引不正确,结果如下:

但是在对列表进行升序排序之后,结果就不一样了:

Collections.sort(list);  // sort()这个方法用来升序排序;

int intB = Collections.binarySearch(list, 3);

System.out.println("list集合:" + list);

System.out.println("3在集合中的索引位置:" + intB);

由于binarySearch方法默认的是升序排序,所以与列表的排序一致,返回的索引正确,结果如下,:

2、binarySearch(List list, T key,Comparator c):比上面多了一个参数,这个参数是用来自定义排序规则的,如果自定义了降序排序,则list集合也要降序排序,否则返回的索引不准确,要保证List集合的排序和binarySearch方法的排序一致。

Collections.reverse(list);// reverse()反转顺序,之前是升序则反转后是降序

System.out.println("list集合:" + list);

int a = Collections.binarySearch(list, 5, new Comparator() {

@Override

public int compare(Integer o1, Integer o2) {

// 从大到小(即降序排序)

return o2 - o1;

}

});

返回的索引正确,结果如下:

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值