java中自定义数组排序比较器_使用Java中的自定义比较器在数组中搜索

为什么无论strToSearch变量拥有什么,它总是返回49999?即使使用clank搜索变量,它也会返回相同的结果.我错过了什么吗?

String[] arr = new String[100000];

String strToSearch = "12";

for (int i = 0; i < arr.length; i++) {

arr[i] = i+","+i;

}

Arrays.sort(arr, new Comparator() {

@Override

public int compare(String o1, String o2) {

if(o1 != null && o2 != null && !o1.isEmpty() && !o2.isEmpty() && o1.indexOf(",") != -1 && o2.indexOf(",") != -1) {

String[] o1Arr = o1.split(",");

String[] o2Arr = o2.split(",");

Integer one = Integer.parseInt(o1Arr[0]);

Integer two = Integer.parseInt(o2Arr[0]);

return one.compareTo(two);

}

return 0;

}

});

System.out.println(Arrays.binarySearch(arr, strToSearch, new Comparator() {

@Override

public int compare(String o1, String o2) {

if(o1 != null && o2 != null && !o1.isEmpty() && !o2.isEmpty() && o1.indexOf(",") != -1 && o2.indexOf(",") != -1) {

String[] o1Arr = o1.split(",");

String[] o2Arr = o2.split(",");

return o1Arr[0].compareTo(o2Arr[0]);

}

return 0;

}

}));

我的数组包含逗号分隔的值,我想在数组元素中的逗号之前基于字符串进行搜索.还有其他简单的解决方案吗?我还制作了一个自定义方法,该方法可以遍历数组并找到字符串,但是我正在寻找其他选择.

解决方法:

Arrays.binarySearch(…)上的JavaDoc声明必须已对数组进行排序,因此比较器实际上将数组值与搜索字符串进行比较,并且不再用于对数组进行排序.

这意味着您将得到诸如compare(arr [x],“ 12”)之类的内容,并且if条件指出两个字符串必须包含逗号,否则它们是相等的.而且“ 12”不包含任何逗号,因此使“ 12”等于数组中的每个元素(总是返回0).

编辑:

查看源代码似乎支持我的假设.

有这行,例如:

//c is the Comparator

//midVal is an element of your array

//key is the key parameter you passed to binarySearch(...)

c.compare(midVal, key);

返回49999的原因是第一中间值位于索引mid =(低高)> 1是(0 99999)> 1 == 49999,由于比较器返回0,因此认为值相等.而繁荣,价值就是“发现”.

标签:java,arrays,search

来源: https://codeday.me/bug/20191010/1885460.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值