所以我有一个战斗机的ArrayList,在这个arraylist中,它包含具有以下变量的Fighter对象:

public Fighter()
{
  super();
  this.name = "";
  this.ageGroup = "standard";
  this.time = 0;
  this.number = this.nextNumber;
  this.nextNumber++;

}


我想做的是通过这个arraylsit搜索具有ageGroup标准的任何人,然后将它们添加到TreeSet中。基本上是为高级年龄组或初级年龄组等提供一组结果。我使用TreeSet的原因是列表必须始终对键进行排序。

这些是我要填充的列表:

  juniorResults = new TreeSet<>();
  standardResults = new TreeSet<>();
  seniorResults = new TreeSet<>();


所以我已经走了这么远:

public void categorise(){
  Iterator iter = fighters.iterator();
  while (iter.hasNext()){
     if(runners.contains(Runner.getAgeGroup("senior"))){
        Runner.getAgeGroup("senior");
     }
  }


如果我说实话,我对此很迷茫,因此任何帮助/教学要点将不胜感激!

最佳答案

您应该能够执行以下操作:

public void categorise() {
    for (Fighter fighter : fighters) {
        switch (fighter.getAgeGroup()) {
            case "senior":
                seniorResults.add(fighter);
                break;
            case "standard":
                standardResults.add(fighter);
                break;
            case "junior":
                juniorResults.add(fighter);
                break;
        }
    }
}


为了使其正常工作,您的Fighter类应具有一个方法(最好是抽象的),该方法将其年龄组作为StringFighter#getAgeGroup返回。

关于java - 在ArrayList中搜索值,然后将值和键复制到新的TreeSet中,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/43744588/

10-13 07:26