当前位置: 代码迷 >> Eclipse >> JAVA数组如何自动排序,不用冒泡
  详细解决方案

JAVA数组如何自动排序,不用冒泡

热度:58   发布时间:2016-04-23 13:33:18.0
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代表小于。
  相关解决方案