Java Custom ArrayList对象排序

时间:2011-12-06 14:48:57

标签: java sorting collections arraylist

我在排序ArrayList我自己的对象时遇到了问题。

我的这些对象的类看起来像这样:

public class Robal {
    int[] gen = new int[5];
    int fit;
    Random losuj = new Random();

    public Robal(int przelacz) {
        for (int i=0; i<5; i++ ) {
            gen[i]=losuj.nextInt(2);
        }
        fit=dopasuj(gen, przelacz);    
    }

    int dopasuj(int[] gen, int przelacz)    {
        int toDec=(gen[0]*1)+(gen[1]*2)+(gen[2]*4)+(gen[3]*8)+(gen[4]*16);
        return y(toDec, przelacz);
    }

    int y(int toDec, int przelacz) {
        if (przelacz == 1) {
            return toDec*toDec;
        } else if (przelacz == 2) {
            return 1;
        } else if(przelacz == 3) {
            return 1;
        } else if(przelacz == 4) {
            return 1;
        } else {
            return 1;
        }
    }

    void drukuj(int i) {
        System.out.println("Geny Robala "+i+": "+gen[0]+" "+gen[1]+" "+gen[2]+" "+gen[3]+" "+gen[4]+"\tfit:"+fit);
    }
}

和我的主要课程是:

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;

public class PE {

public static void main (String[] args){
ArrayList<Robal> Robale = new ArrayList<Robal>();
int i=0;
while(i!=5){
Robale.add(new Robal(1));
i++;
}
Robale.get(0).drukuj(1);
Robale.get(1).drukuj(2);
Robale.get(2).drukuj(3);
Robale.get(3).drukuj(4);

Collections.sort(Robale, new Comparator<Robal>() {
public int compare(Robal a, Robal b){
return a.fit - b.fit;
}
});

Robale.get(0).drukuj(1);
Robale.get(1).drukuj(2);
Robale.get(2).drukuj(3);
Robale.get(3).drukuj(4);


}


}

但大部分时间排序前后的数据都不一样...... 示例结果:

Geny Robala 1: 0 1 1 0 0 fit:36
Geny Robala 2: 1 0 1 0 1 fit:441
Geny Robala 3: 1 1 0 0 1 fit:361
Geny Robala 4: 0 1 1 1 0 fit:196
Geny Robala 1: 0 1 1 0 0 fit:36
Geny Robala 2: 0 0 0 1 0 fit:64
Geny Robala 3: 0 1 1 1 0 fit:196
Geny Robala 4: 1 1 0 0 1 fit:361

2 个答案:

答案 0 :(得分:1)

您确定在排序列表时没有实例化新的Robal吗?这将导致随机值转移

答案 1 :(得分:1)

您正在向阵列添加5个项目,并且在排序之前和之后仅打印4个项目。似乎未分类列表中的第5项使其成为前4名。您是否可以打印另一项并查看事情是否良好?