【问题标题】:Java Custom ArrayList Object SortingJava 自定义 ArrayList 对象排序
【发布时间】:2011-12-06 14:48:57
【问题描述】:

我在对我自己的对象的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

【问题讨论】:

  • 你如何比较数据?
  • 哪些数据在谈论?数组中的对象是否被修改?
  • 不,数据没有以任何方式修改...
  • 假设后四行是前四行显示的对象排序的结果,“fit”的值是按顺序排列的,每个“fit”值关联的数字列表前后不要改变。所以有什么问题?我觉得很好。
  • 您是如何从1 0 1 0 1 fit:441 变成0 0 0 1 0 fit:64 的?

标签: java sorting collections arraylist


【解决方案1】:

您确定在排序列表时没有实例化新的 Robal 吗?这会导致随机值发生变化

【讨论】:

  • 好的问题找到了...这里:while(i!=5){ wrong number...我有 5 个 Robal 实例...
【解决方案2】:

您将 5 个项目添加到数组中,并且在排序前后仅打印 4 个。似乎未排序列表中的第 5 项进入了前 4 名。您可以再打印一项,看看情况是否好?

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2010-12-21
    • 2020-07-25
    • 2016-08-22
    • 2011-02-16
    相关资源
    最近更新 更多