首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > JAVA > Eclipse开发 >

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

2012-04-30 
JAVA数组怎么自动排序,不用冒泡我有一个父类对象数组 Shape[] shapesnewShape[10]这个父类里面存有10个

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代表小于。

热点排行