首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在对项之间反复选择后确定排序的算法

在对项之间反复选择后确定排序的算法
EN

Stack Overflow用户
提问于 2019-05-24 08:59:37
回答 2查看 649关注 0票数 1

我想写一个小程序来帮助我根据许多一对一比较的结果对项目进行排序。

因此,如果我有100个条目,我将允许用户重复地在这组中的两个随机选择项中进行选择。假设总共有10.000张选票。第10号项目在1000票中胜出,并赢得了与所有其他项目的直接对抗。第90条以100票获胜,赢得40票,输掉了60次直接对抗。是否有一种现有的算法(例如,来自推荐系统或类似的算法),可以用来构造这些项目的排序列表?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-05-24 09:12:48

一个简单的方法是根据win percentage (即total wins/total confrontations )进行排序。

如果你想有一个单一的得分机制,你可以reward的赢家和punish的输家的固定数量,然后排名根据最后的分数。

最后,您可以看看Elo ranking algorithm,它计算了每个项目赢得对抗的概率,以及rewards and punishes相对于这些概率的概率。

示例

代码语言:javascript
复制
# Probability
A higher chance of winning than B

# Case1: A wins
A +small reward
B -small punishment

# Case2: B wins
A -large punishment
B +large reward
票数 2
EN

Stack Overflow用户

发布于 2019-05-24 09:25:03

如果您只想做您解释的(您没有要求任何优化或类似的),那么算法是非常简单的。

  1. 建立所有可能比较的矩阵。
  2. 按其列中获胜的数量对每个元素进行排序。

在伪代码中,这可能如下所示:

代码语言:javascript
复制
# given a list of elements:
elements = ...

# build the comparison matrix:
matrix = Matrix(n, n)
for i in 0..n-1:
  for j in 0..n-1:
    matrix[i][j] = elements[i] < elements[n]

# rank each element by its "wins":
for i in 0..n-1:
  ranks[i] = sum(matrix[i])

在此之后,ranks[i]将说明每个i的elements[i]级别,这样您就可以按照rankselements进行排序。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56289192

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档