JAVA数组怎么自动排序,不用冒泡
我有一个父类对象数组 Shape[] shapes=new Shape[10];
这个父类里面存有10个子类,但是我要调用Arrays.sort()这个方法排序对象数组里面的面积怎么弄??
Arrays.sort(shapes) 貌似直接这样不可以额
求高手
[解决办法]
意思是按面积排序吧
用Arrays.sort(Object[] arg0, Comparator<? super Object> arg1)
写一个Comparator就行了
[解决办法]
請參考我的blog,自定義排序Comparator。
http://blog.csdn.net/iisgirl/article/details/7269833
[解决办法]
我假设你的 Shape有个getArea方法 返回一个Double代表面积
Arrays.sort(shapes, new Comparator<Shape>() {
@Override
public int compare(Shape s1, Shape s2) {
return s1.getArea().compareTo(s2.getArea());
或者这样
double d = s1.getArea() - s2.getArea();
if(d > 0) {
return 1;
} else if (d < 0) {
return -1;
} else {
return 0;
}
}
});
Comparator只要重写一个 compare方法就行了,返回值大于0代表大于,返回0代表小于。