gpt4 book ai didi

java - 如何对文本文件中的并行数组进行排序

转载 作者:行者123 更新时间:2023-12-01 12:12:49 24 4
gpt4 key购买 nike

所以我已经尝试了几乎所有的方法,但就是无法对其进行排序,我必须使用这种排序算法..

这是我到目前为止的代码,但是当我运行该程序时,它会按正常顺序而不是降序打印数组。

BufferedReader filein = new BufferedReader(new FileReader("Employees.txt"));

int count = Integer.parseInt(filein.readLine());
String[] names = new String[count];
int[] years = new int[count];
int i;
int pass;
int loc;
int temp;
String tempNames;
String passNames;

System.out.println("My Company Employee Search");
System.out.println("--------------------------");
System.out.println("");



for(i=0; i < count-1; i++) {
names[i] = filein.readLine();
years[i] = Integer.parseInt(filein.readLine());
}//populate the arrays from filein

for(pass = 0; pass<count-1;pass++){
loc = pass;
for(i=pass+1; i<count; i++) {
if(years[i]<years[loc]) {
loc = i;
}//end if
}//end of inner loop



temp = years[loc];
years[loc] = years[pass];
years[pass] = temp;

names[loc]=names[pass];

System.out.println(years[loc]+" "+names[loc]);
}//end of containg loop

我正在加载的文本文件是:

6
Luke
2013
Bob
1980
Ben
2000
Cam
2000
Holly
2001
Joe
1997

最佳答案

创建一个普通的旧 Java 对象(a POJO )并将文件内容存储在该 POJO 的实例中。只要你让你的POJO实现Comparable然后你可以使用 Arrays.sort(Object[])订购您需要多长的时间。

编辑

那么您需要更改第二个交换。

names[loc]=names[pass];

盲目替换names[loc]而不保存之前的值。

String tempName = names[loc];
names[loc] = names[pass];
names[pass] = tempName;

关于java - 如何对文本文件中的并行数组进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27181941/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com