1

我正在使用网格来显示玩家的排名。该列表按后端的各种比较器排序,但可能仍然存在 2 行具有相同排名的情况。在下面的示例中,前两行应该有编号#1,最后两行应该都是#2。

在此处输入图像描述

我将排名数字实现为一列,如下所示:

rankings.addColumn(this::getRowIndex).setWidth("2em")
            .setResizable(true);

使用这种方法:

private String getRowIndex(TeamHasFormatRecord thfr)
  {
    index++;
    return String.valueOf(index);
  }

这是一个基本的计数器。我能想到的唯一方法基本上是获取每个条目并找到它在列表中的位置,但我认为这可能太重并且不会很好地升级。

有什么建议么?

更新 这是当前的比较器:

    Comparator.comparingDouble((TeamHasFormatRecord thfr) -> thfr.getPoints())
              .thenComparingDouble(thfr -> thfr.getMean())
              .thenComparingDouble(thfr -> thfr.getStandardDeviation())
              .reversed()
4

2 回答 2

1

创建一个 TreeSet 并将每一行的点添加到集合中。使用集合的长度返回排名。

(加 10){10} -> 1

(加 10){10} -> 1

(加 0){10, 0} -> 2

(加 0){10,0} -> 2

于 2019-01-01T20:02:24.947 回答
1

这可以通过在您的getRowIndex方法中稍微更改代码来实现(我将其命名getRanking为它不再是一个简单的索引)。诀窍是存储当前/迭代行的 thfr 以供下一行进行比较。如果他们的得分相同,则不要增加排名

// class fields
private TeamHasFormatRecord lastIteratedThfr;
private int ranking = 0;

private String getRanking(TeamHasFormatRecord thfr)
{
    // hasSameScore() will check for equal points, mean, and standardDerivation.
    if(lastIteratedThfr == null || !thfr.hasSameScore(lastIteratedThfr)){
        ranking++;
    }
    lastIteratedThfr = thfr; // store this thfr for the next thfr to compare to
    return String.valueOf(ranking);
}

此解决方案仅在您事先对网格进行排序并且不允许用户求助时才有效。我想你已经这样做了。

于 2019-01-14T16:45:52.143 回答