[英]How do I fix my sortData and compareTo method. I keep receiving “cannot be converted to error.”
我一直收到错误消息:不兼容的类型:当我尝试将数组传递给compareTo方法时,BingoPlayer无法转换为BingoPlayer []。 我不太确定如何解决此问题。
我正在从文本文件读取数据。 这是该文件的内容:
导入java.io。 ; 导入java.util。 ;
public static void sortData()
{
int n = test.length;
int m =0;
BingoPlayer temp;
for(int i=0; i < n; i++)
{
for(int j=1; j < (n-i); j++)
{
m = compareTo((test[j], test[j+1];
if(m > 0)
{
temp = test[j-1];
test[j-1] = test[j];
test[j] = temp;
}
}
}
}
public static int compareTo(BingoPlayer[] player1, BingoPlayer[] player2)
{
for(int i =0; i < 10; i++)
{
if(player1[i].firstName.compareTo(player2[i].firstName) != 0)
return player1[i].firstName.compareTo((player2[i].firstName));
else if (player1[i].lastName.compareTo(player2[i].lastName) != 0)
return player1[i].lastName.compareTo((player2[i].lastName));
else
return player1[i].lastName.compareTo(player2[i].lastName);
}
}
}
由于您没有提供所有代码,因此我将假设“测试”是BingoPlayer对象的数组。
我建议您更改compareTo方法,以仅将1个BingoPlayer与另一个BingoPlayer进行比较。 通过代码的工作方式,您可以比较测试中的所有内容,然后调用一种方法来再次比较测试中的所有内容。 让我们减少冗余并尝试执行以下操作:
public static void sortData()
{
int n = test.length;
int m =0;
BingoPlayer temp;
for(int i=0; i < n; i++)
{
for(int j=1; j < (n-i); j++)
{
m = compareTo((test[j], test[j+1];
if(m > 0)
{
temp = test[j-1];
test[j-1] = test[j];
test[j] = temp;
}
}
}
}
public static int compareTo(BingoPlayer player1, BingoPlayer player2)
{
if(player1.firstName.compareTo(player2.firstName) != 0)
return player1.firstName.compareTo((player2.firstName));
else if (player1.lastName.compareTo(player2.lastName) != 0)
return player1.lastName.compareTo((player2.lastName));
else
return player1.lastName.compareTo(player2.lastName);
}
}
同样,我不得不假设“测试”是BingoPlayer对象的数组。 如果真是这样,那么您正在尝试将两个单个BingoPlayer对象发送到期望有两个BingoPlayer数组的方法。 如上所示,对您的compareTo进行更改应该可以修复您的程序。
您的compare方法应该使用两个BingoPlayer对象,而不是这些对象的数组。
您还应该阅读有关Comparable和Comparator接口的信息。
编辑:Comparable和Comparator实现有一些代码片段
class BingoPlayer implements Comparable<BingoPlayer> {
// rest of your class
String firstName, lastName;
@Override
public int compareTo(BingoPlayer player) {
if(firstName.compareTo(player.firstName) != 0)
return firstName.compareTo((player.firstName));
else if (lastName.compareTo(player.lastName) != 0)
return lastName.compareTo((player.lastName));
else
return lastName.compareTo(player.lastName);
}
}
您可以像这样使用它:
player1.compareTo(player2);
另一种方法是创建自己的Comparator类:
class BingoPlayerComparator implements Comparator<BingoPlayer> {
@Override
public int compare(BingoPlayer player1, BingoPlayer player2) {
if(player1.firstName.compareTo(player2.firstName) != 0)
return player1.firstName.compareTo((player2.firstName));
else if (player1.lastName.compareTo(player2.lastName) != 0)
return player1.lastName.compareTo((player2.lastName));
else
return player1.lastName.compareTo(player2.lastName);
}
}
可以这样使用:
BingoPlayerComparator c = new BingoPlayerComparator();
c.compare(player1, player2);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.