我在Java领域还很新,我才刚刚开始在计算机科学大学课程中学习它。
我正在编写一个程序,该程序具有一个ArrayList
,该Personality
包含一个称为individual
的PersonalityList
对象,这些对象在private ArrayList<Personality> individual;
类中声明为:Personality
这些votes
对象包含类型为int
的称为ArrayList
的私有字段。
我还在PersonalityList
类中声明了相同的rankedList
,但具有不同的名称-private ArrayList<Personality> rankedList;
-像这样:top(int value)
在我的程序中,我做了一个叫做individual
的方法。在这种方法中,我尝试使用while循环浏览value
列表,从该列表中获取对象,只要它们的索引号低于rankedList
参数的值,然后将其添加到rankedList
列表中,然后然后按votes
字段的顺序对top
列表进行排序,投票数最高的对象将排在列表的首位(索引为0)。当前,这是我的Personality
方法:
public void top(int value)
{
int index = 0;
int listSize = individual.size();
rankedList = new ArrayList<Personality>();
if(value > listSize) {
value = listSize;
}
else {
System.out.println("Error: Enter a positive integer value.");
}
if(listSize > 0) {
while(index < value) {
Personality prsn = individual.get(index);
rankedList.add(prsn);
System.out.println(prsn.getDetails());
index++;
}
}
else {
System.out.println("Error: The array list has no personalities stored inside it.");
}
}
我目前正在使用
getDetails()
类中定义的Personality
方法(包含对象字段)打印while循环获得的每个Collections.sort
对象的详细信息,只是为了检查它是否获取了正确数量的对象。我了解我需要通过查看其他Stack Overflow帖子来使用
top
功能,但是即使查看了这些帖子的答案,我也不知道如何在我的代码中实现它。我已经尝试过,但是我一直在向我抛出错误,我不太了解。任何帮助,最好是特定的代码,将不胜感激。谢谢!
更新:
感谢示例代码@camickr。
在我的Personality类中,添加了以下代码:
static class votesComparator implements Comparator<Personality>
{
public int compare(Personality p1, Personality p2)
{
return p1.getVotes() - p2.getVotes();
}
}
我还在
PersonalityList
类中将我的Collection.sort(rankedList)
方法编辑为:if(listSize > 0) {
while(index < value) {
Personality prsn = individual.get(index);
rankedList.add(prsn);
System.out.println(prsn.getDetails());
index++;
}
Collections.sort(rankedList);
System.out.println("Sort by Natural order");
System.out.println("\t" + people);
}
else {
System.out.println("Error: The array list has no personalities stored inside it.");
}
但是,现在我得到一个错误,指出“在处调用了“找不到适合sort(java.util.List)的合适方法””。
这是什么原因呢?
最佳答案
您发布的代码与排序无关。重要的代码是您的Personality
类。您要么:
需要在您的课程上实现Comparable或
创建一个自定义比较器
这是一个示例,显示了这两种方法的示例:
/*
** Use the Collections API to sort a List for you.
**
** When your class has a "natural" sort order you can implement
** the Comparable interface.
**
** You can use an alternate sort order when you implement
** a Comparator for your class.
*/
import java.util.*;
public class Person implements Comparable<Person>
{
String name;
int age;
public Person(String name, int age)
{
this.name = name;
this.age = age;
}
public String getName()
{
return name;
}
public int getAge()
{
return age;
}
public String toString()
{
return name + " : " + age;
}
/*
** Implement the natural order for this class
*/
public int compareTo(Person p)
{
return getName().compareTo(p.getName());
}
static class AgeComparator implements Comparator<Person>
{
public int compare(Person p1, Person p2)
{
return p1.getAge() - p2.getAge();
}
}
public static void main(String[] args)
{
List<Person> people = new ArrayList<Person>();
people.add( new Person("Homer", 38) );
people.add( new Person("Marge", 35) );
people.add( new Person("Bart", 15) );
people.add( new Person("Lisa", 13) );
// Sort by natural order
Collections.sort(people);
System.out.println("Sort by Natural order");
System.out.println("\t" + people);
// Sort by reverse natural order
Collections.sort(people, Collections.reverseOrder());
System.out.println("Sort by reverse natural order");
System.out.println("\t" + people);
// Use a Comparator to sort by age
Collections.sort(people, new Person.AgeComparator());
System.out.println("Sort using Age Comparator");
System.out.println("\t" + people);
// Use a Comparator to sort by descending age
Collections.sort(people, Collections.reverseOrder(new Person.AgeComparator()));
System.out.println("Sort using Reverse Age Comparator");
System.out.println("\t" + people);
}
}