3

我有一个特许经营类,其中包含所有者(特许经营名称的所有者)、状态(特许经营所在州的 2 个字符串)和销售额(当天的总销售额)

public class Franchise implements Comparable <Franchise>  {
final String owner;
final String state;
final double sales;

protected Franchise(String owner, String state, double sales ) {
    this.owner = owner;
    this.state = state;
    this.sales = sales;
}
public String toString() {
    String str = state + ", " + sales + ", " + owner;
    return str;
}
public String getState() {
    return state;
}
public double getSales() {
    return sales;
}
public int compareTo(Franchise that) {
    double thatSales = that.getSales();
    if (this.getState().compareTo(that.getState()) < 0)  
        return -1;
    else if (this.getSales() > thatSales)
        return -1;
    else if (this.getSales() < thatSales)
            return 1;
    else
        return 0;
}
}

compareTo 基于状态 ASCENDING 和 sales DESCENDING

import java.util.ArrayList;
import java.util.Collections;

public class FranchiseTester {

public static void main(String[] args) {
    ArrayList<Franchise> franchises = new ArrayList<Franchise>();
    Franchise a = new Franchise("Andrew Luck", "IN", 1270.5);
    Franchise b = new Franchise("Ray Rice", "MD", 1210);
    Franchise c = new Franchise("Alfred Morris", "WA", 980.5);
    Franchise d = new Franchise("Roddy White", "GA", 670);
    Franchise e = new Franchise("Greg Olsen", "SC", 740);
    Franchise f = new Franchise("T.Y. Hilton", "IN", 950);
    Franchise g = new Franchise("Julio Jones", "GA", 560);

    franchises.add(a);
    franchises.add(b);
    franchises.add(c);
    franchises.add(d);
    franchises.add(e);
    franchises.add(f);
    franchises.add(g);

    Collections.sort(franchises);

    for(int i = 0; i < franchises.size(); i++) {   
        System.out.print(franchises.get(i) + "\n");
    } 
}

}

当我在没有正确比较的情况下比较这些特许经营对象Collections.sort时,但是当我使用Collections.sort我在这里的类似进行测试时,我得到如下输出:

GA, 670.0, Roddy White
GA, 560.0, Julio Jones
IN, 1270.5, Andrew Luck
IN, 950.0, TY Hilton
MD, 1210.0, Ray Rice
SC, 740.0, Greg Olsen
WA, 980.5, Alfred Morris

该州仍在正确比较,但没有按销售额进行正确比较(特定统计数据的较低销售额应该首先出现)

我认为 .sort 默认比较字符串是状态仍然正确的原因,我的问题是如何实现它以根据销售额进行比较?

4

4 回答 4

2

在您的问题陈述中,您说"compareTo is based on state ASCENDING and sales DESCENDING"。基于此,您的结果是有效的。各州按升序排列,每个州的销售按降序排列。在下一个声明中,您要说(应首先降低特定统计数据的销售额)。所以基本上你有两个相互冲突的要求。两者不能同时进行。

换句话说,您是否希望您的程序执行其他操作,例如两者都应该升序或降序或其他顺序。如果是,那么您必须相应地修改您的 compareTo 方法。

于 2013-09-12T03:33:20.410 回答
1

你必须修改你的compareTo方法。因为您在比较状态后返回。所以你必须比较状态,但也要比较销售额。

例如:

public int compareTo(Franchise that) {
    int stateComparition = this.getState().compareTo(that.getState()); 
    Double sales = Double.valueOf(this.getSales());    
    Double thatSales = Double.valueOf(that.getSales());
    int salesComparition = sales.compareTo(thatSales);    

    if(stateComparition == 0){
        if(salesComparition > 0)
             return -1;
        else if(salesComparition < 0)
             return 1;
        else
             return 0;
    }
       return stateComparition;         
}
于 2013-09-12T02:55:43.603 回答
0

Comparable 只会给出一种比较方式。这也可以使用 Comparator 接口来完成。

Collections.sort(list, new Comparator<Franchise>() {
    @Override
    public int compare(Franchise obj1, Franchise obj2) {
        if(obj1.getState().compareTo(obj2.getState()) == 0)
        {
            Double a1 =obj1.getSales();
            Double a2 = obj2.getSales();
            return a2.compareTo(a1);
        }
        return obj1.getName().compareTo(obj2.getName());
    } 
}
于 2018-04-13T18:13:32.480 回答
0

这是因为首先比较条件是根据状态进行比较。如果当前对象的状态不小,那么只会进行基于销售额的比较。根据您的代码,在状态下,您希望当前对象的状态小于比较状态,但是在销售比较中,您希望当前对象的销售额大于比较对象。这就是为什么你会得到不同的结果。状态按升序进行比较,销售额按降序进行比较。这完全取决于您从 compareTo 函数返回的内容。

public int compareTo(Franchise that) {
double thatSales = that.getSales();
if (this.getState().compareTo(that.getState()) < 0)  
    return -1;
else if (this.getSales() < thatSales)
    return -1;
else if (this.getSales() > thatSales)
        return 1;
else
    return 0;
}

希望这段代码对您有所帮助。你可以在这里找到很好的解释

于 2016-10-23T10:30:07.113 回答