我必须阅读包含内容的文件
2011 Regular Season
Boston 162 5710 875 1600 352 35 203
NY_Yankees 162 5518 867 1452 267 33 222
Texas 162 5659 855 1599 310 32 210
Detroit 162 5563 787 1540 297 34 169
St.Louis 162 5532 762 1513 308 22 162
Toronto 162 5559 743 1384 285 34 186
Cincinnati 162 5612 735 1438 264 19 183
Colorado 162 5544 735 1429 274 40 163
Arizona 162 5421 731 1357 293 37 172
Kansas_City 162 5672 730 1560 325 41 129
这是我用
读到的代码static String specstat[][] = new String[1000][1000];
public static void main(String args[]) {
Arrays.sort(specstat, 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);
}
});
for (final String[] s : specstat) {
System.out.println(s[0] + " " + s[0]);
}
execute();
}
public static String[][] execute() {
int line = 0;
try {
BufferedReader in = new BufferedReader(new FileReader(
"files/input.txt"));
String str;
while ((str = in.readLine()) != null) {
if (str.trim().length() == 0) {
continue; // Skip blank lines
}
specstat[line] = str.split("\\s+");
line++;
}
in.close();
} catch (IOException e) {
System.out.println("Can not open or write to the file.");
}
return specstat;
}
如何根据文本文件中最后一列(或任何一列)的第一列对2D数组进行排序?
答案 0 :(得分:3)
我不会为此目的使用2D数组。
我会创建一个Team
类,并为文件格式中的每个字段定义实例变量。然后我将创建一个实现Comparator
(例如,TeamComparator
)的类,该类定义如何根据所需的标准比较Teams
。
然后,您可以拥有Teams
或List
Teams
的数组。
最后,您可以使用
对数组进行排序Arrays.sort(teamsArray, new TeamComparator())
或带有
的列表Collections.sort(teamsList, new TeamComparator())
答案 1 :(得分:3)
根据我的理解,您希望通过排列数组内部的位置来对2D数组进行排序。您可以Arrays.sort()
使用自定义Comparator
,如下所示:
Arrays.sort(specstat, new Comparator<String[]>() {
@Override
public int compare(String[] array1, String[] array2) {
//do your comparison here...
}
});
使用String.compare()
或使用Integer.parseInt(String s)
比较数值可能会有所帮助。如果要对2D数组中的各个String数组进行排序,则必须单独对每个数组进行排序。
编辑:请参阅建议的比较方法的评论。
答案 2 :(得分:0)
使用QuickSort对数组进行排序
答案 3 :(得分:0)
您可以将Arrays.sort与比较器一起使用。