我正在尝试利用可比较的接口对数组进行排序。compareTo() 方法是这样编写的,因此钻石首先按胡萝卜排序,然后按净度或颜色排序,以对特定钻石更好的为准。由于有23个颜色等级,但净度只有11个等级,所以将前两个颜色等级视为与一级净度等级相等,后两个颜色等级与二级净度等级相同,以此类推. 我不确定如何将颜色与清晰度进行比较,因为一个是字符串,另一个是字符。这是我到目前为止所拥有的。
public Diamond(String sN, double car, String clar, char col, String cutType)
{
stockNumber = sN;
carot = car;
clarity = clar;
color = col;
cut = cutType;
}
public int compareTo(Diamond other)
{
if (getCarot() < other.getCarot())
{
return 1;
}
else if(getCarot() > other.getCarot())
{
return -1;
}
else return 0;
}
public String toString()
{
return "{stockNumber :: " +getStock() + " carot :: " +getCarot() + " clarity :: " +getClarity()+ " color :: " +getColor() + " cut :: " +getCut()+"}";
}
//gets the stock number of the diamond
public String getStock()
{
return stockNumber;
}
//gets the carot size of the diamond
public double getCarot()
{
return carot;
}
//gets the clarity of the diamond
public String getClarity()
{
return clarity;
}
//gets the color of the diamond
public char getColor()
{
return color;
}
//gets the cut of the diamond
public String getCut()
{
return cut;
}
钻石[] 石头 = 新钻石[16];
stones[0] = new Diamond( "A1023", 1.0, "VS1", 'F', "brilliant");
stones[1] = new Diamond( "A5911", 1.1, "VVS2", 'G', "rose");
stones[2] = new Diamond( "C5427", 1.0, "VS1", 'D', "princess");
stones[3] = new Diamond( "D8307", 1.6, "SI1", 'H', "brilliant");
stones[4] = new Diamond( "B4825", 0.3, "I1", 'D', "rose");
stones[5] = new Diamond( "A1844", 2.1, "VS2", 'D', "lozenge");
stones[6] = new Diamond( "A3747", 3.1, "SI2", 'W', "baguette");
stones[7] = new Diamond( "E6393", 2.3, "VS2", 'I', "brilliant");
stones[8] = new Diamond( "C5619", 2.8, "VVS1", 'E', "pear");
stones[9] = new Diamond( "E8348", 1.4, "VS2", 'G', "brilliant");
stones[10] = new Diamond( "D2381", 1.7, "I3", 'G', "brilliant");
stones[11] = new Diamond( "C9253", 1.3, "VS2", 'H', "baguette");
stones[12] = new Diamond( "G3459", 2.1, "VS2", 'H', "rose");
stones[13] = new Diamond( "B3598", 2.4, "VVS2", 'D', "pear");
stones[14] = new Diamond( "D9836", 2.8, "IF", 'E', "princess");
stones[15] = new Diamond( "E1046", 2.2, "FL", 'E', "rose");
Arrays.sort( stones );
for ( int j=0; j<stones.length; j++ )
System.out.println( stones[j].toString() );
}
}