所以我有一个战斗机的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
类应具有一个方法(最好是抽象的),该方法将其年龄组作为String
,Fighter#getAgeGroup
返回。关于java - 在ArrayList中搜索值,然后将值和键复制到新的TreeSet中,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/43744588/