我创建了一个二维字符串数组(称为数据),其中第一个位置包含一个整数(作为字符串),第二个位置包含一个文件链接。
示例:
["3", "Test3.pdf"]; ["1", "Test1.pdf"]; ["2", "Test2.pdf"]; ["10", "Test10.pdf"]
所以现在我需要对数组按整数升序排序。所以排序的结果应该是一个排序数组,如下所示:
["1", "Test1.pdf"]; ["2", "Test2.pdf"];["3", "Test3.pdf"];["10", "Test10.pdf"]
我找到了一些示例代码:
Arrays.sort(data, new Comparator<String[]>() {
@Override
public int compare(final String[] entry1, final String[] entry2) {
final String time1 = entry1[0];
final String time2 = entry2[0];
return time1.compareTo(time2);
}
});
但问题是,在这种情况下,它将它与字符串逻辑进行比较,因此结果将是 -> 1,10,2,3。所以我无法用这个来存档结果。你知道我能做什么吗?你只能有一种类型的二维数组?不是字符串和整数的混合?
最佳答案
可以通过将第一个元素转换为整数来完成比较,如以下代码片段所示:
Arrays.sort(data, new Comparator<String[]>() {
@Override
public int compare(final String[] entry1, final String[] entry2) {
final Integer time1 = Integer.valueOf(entry1[0]);
final Integer time2 = Integer.valueOf(entry2[0]);
return time1.compareTo(time2);
}
});
关于java - 用整数对二维字符串数组进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40485338/