所有者 (フランチャイズの名前の所有者)、州 (フランチャイズがある州の 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 は州の昇順と売上の降順に基づいています
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 がデフォルトで文字列を比較するのは、状態がまだ正しい理由だと思います。私の質問は、販売に基づいて比較するためにどのように実装するのですか?