为什么49999
无论什么strToSearch
变量成立,它总是返回?即使使用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<String>() {
@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<String>() {
@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;
}
}));
我的数组包含逗号分隔的值,我想在数组元素中的逗号之前基于字符串进行搜索。还有其他简单的解决方案吗?我还制作了一个自定义方法,该方法可以遍历数组并找到字符串,但是我正在寻找其他选择。
JavaDoc on Arrays.binarySearch(...)
声明必须已对数组进行排序,因此比较器实际上将数组值与搜索字符串进行比较,并且
不 用于对数组进行再次排序。
这意味着您得到类似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
值位于index处mid = (low + high) >> 1
,(0 + 99999) >> 1 == 49999
并且由于比较器返回0,因此认为值相等。而繁荣,价值就是“发现”。
问题内容: 我想用自定义排序顺序在Java中创建一个。字符串排序的键需要根据第二个字符进行排序。这些值也是字符串。 样本图: 问题答案: 您可以像这样使用自定义比较器: 样品: 请注意,这只是假设字符在索引1处有一个字符。 另外,您也可以使用以下比较: 通常,此减法“技巧”是无效的,但在这里可以正常使用,因为减法2 不会溢出。 不过,上面的and 解决方案更具可读性。
我创建了一个自定义比较器,可以按降序对获胜数进行排序,但我不确定它是如何工作的,有人能解释一下这是如何按降序排序的吗?
在我的PriorityQueue中,我有两种类型的客户,即VIP和常规客户。我想先为贵宾服务,再为常客服务。 如果CustomerID<100,则视为VIP。 如果客户是VIP,他会排在队列中VIP部分的最后 更新:我不想排序任何其他列除了VIP。我不想添加“日期”,因为它感觉像是一个黑客,而不是理解Java是如何工作的。
我试图用Priorityqueue和自定义比较器实现MST,但是我在O(n)时间内用它构建最小堆时遇到了问题。问题是Priorityqueue只有一个构造函数允许在O(n)中创建Priorityqueue,但它不使用任何比较器作为参数。我想让它使用我的自定义比较器。有解决这个问题的方法吗?AddAll()将失去对MST使用最小堆的目的,因为它是O(nlogn)方法。这是我的代码。 我想使用的比较器
本文向大家介绍Python3.x中自定义比较函数,包括了Python3.x中自定义比较函数的使用技巧和注意事项,需要的朋友参考一下 在Python3.x的世界里,cmp函数没有了。那么sorted,min,max等需要比较函数作为参数的函数该如何用呢? 以min函数的定义为例,有两种重载形式: 单参数(一个迭代器): 多参数(多个待比较内容): 本文主要讨论key=func参数的使用 。举例说明吧
问题内容: 为什么m和t都是假的?比较Java中2个数组的正确方法是什么? 问题答案: 使用Arrays.equals方法。例: