从具有多个属性的列表对象获取最小/最大值

时间:2017-04-23 19:18:40

标签: java android list sorting

如果我有List的对象,其中每个对象具有不同的属性值,如getDistance(),getPrice(),getRating()等。我应该怎么做?

我尝试重写compareTo,但它只能对一个属性进行排序。

我正在尝试使用简单的加法加权方法,我必须获取每个属性的最小/最大值并使用它进行计算。

谢谢!

1 个答案:

答案 0 :(得分:0)

如果您有要使用特定算法排序的对象列表,则可以实现自己的Comparator并使用Collection.sort()方法对列表进行排序。假设您有一个名为容器的类,它是您要比较的对象,它有3个属性;距离,价格和评级。您将实现Container类型的自定义比较器,并定义检查2个Container对象的特定算法。我在下面写了一个例子,其中比较添加了所有3个属性的值,并将它们除以3(在这个例子中除以3是不必要的,但我保留在那里以表明你可以使等式更多如果需要复杂的话,它然后比较哪一个更低并返回一个表示该事实的整数。

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

class Container {
    private double distance;
    private double price;
    private double rating;

    public Container(double distance, double price, double rating) {
        this.distance = distance;
        this.price = price;
        this.rating = rating;
    }

    public double getDistance() {
        return distance;
    }
    public void setDistance(double distance) {
        this.distance = distance;
    }
    public double getPrice() {
        return price;
    }
    public void setPrice(double price) {
        this.price = price;
    }
    public double getRating() {
        return rating;
    }
    public void setRating(double rating) {
        this.rating = rating;
    }
}

class CustomComparator implements Comparator<Container> {

    @Override
    public int compare(Container o1, Container o2) {
        double avgVal1 = (o1.getDistance()+o1.getPrice()+o1.getRating())/3; 
        double avgVal2 = (o2.getDistance()+o2.getPrice()+o2.getRating())/3;
        return avgVal1 < avgVal2 ? -1 : 1;
    }
}

public class CompareTest {

    public static void main(String[] args) {
        List<Container> containerList = new ArrayList<Container>(4);
        containerList.add(new Container(2.0, 3.0, 6.0));
        containerList.add(new Container(1.0, 1.0, 1.0));
        containerList.add(new Container(6.2, 0.0, 0.0));
        containerList.add(new Container(0.0, 3.2, 1.5));
        Collections.sort(containerList, new CustomComparator());
        for(int idx=0; idx<containerList.size(); idx++){
            System.out.println("Distance:" + containerList.get(idx).getDistance() +
                               "\tPrice:" + containerList.get(idx).getPrice() +
                               "\tRating:"  + containerList.get(idx).getRating());
        }
    }
}

运行main()之后,它将以无特定顺序创建Container对象列表,然后使用自定义比较器对它们进行排序,然后将其打印出来,这是输出:

Distance:1.0    Price:1.0   Rating:1.0
Distance:0.0    Price:3.2   Rating:1.5
Distance:6.2    Price:0.0   Rating:0.0
Distance:2.0    Price:3.0   Rating:6.0

您可以在此处看到,根据Container中的所有属性,列表已从最低到最高排序。