- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在考虑让玩家加入游戏的高效算法。由于会有大量玩家,因此算法应该是异步的(即可扩展到集群中任意数量的机器)。有细节:想象有一个无向图(每个节点都是一个玩家)。玩家之间的每条边意味着玩家可以参加同一场比赛,如果没有边则他们不能。我需要实现按照以下标准对玩家进行分组的算法:
我对实现的看法:该图将通过 NoSQL 数据库(来自集群中的不同机器)存储和访问。目前还没有特定的模式(有什么建议吗?)。此外,锁定对单个玩家的访问权限(又名悲观锁)也不是一种选择,因为它是减慢将尝试访问/收集相同玩家的其他进程的潜在瓶颈。
我的问题是:有人实现过这样的算法吗?有什么建议吗?
PS:我已经有了初步的想法,但首先想讨论/检查人们的建议。
谢谢!
编辑1:回应 Thomas Jungblut:使用游戏老虎机是一个有趣的想法,但(只要我理解正确)它在某些情况下可能行不通。 Fox 示例:每场比赛应该正好有 3 名球员。新的 6 名玩家(我们称他们为 A B C D E F,参见示例 1)按以下顺序一一进入图表/队列:A、B、E、F、C、D。
结果只会创建一个游戏(A、B、C),外加 2 个空槽的游戏:(D) 和 (E, F)。但最佳应该是 2 场比赛:(A, C, D) 和 (B, E, F),对吧?
最佳答案
我怀疑您没有正确考虑业务需求。
像带有任意条件的“最佳匹配”这样的短语对我来说是 NP 完全的。对于其中一个具有大型数据集的问题,您不会找到有效的精确解决方案,而只能找到合理的近似值。
次优匹配的成本是多少?您最终不得不等待更长的时间才能找到有人玩。不是真正的问题。
我会实现像这样简单的东西。有一个你正在设置的游戏队列。每个进来的人都试图进入第一场比赛,失败的是第二场比赛,失败的是第三场比赛,依此类推。如果找不到,则在队列末尾创建一个新游戏。游戏在达到最大尺寸时开始,或者在达到最小尺寸后经过固定时间后开始。当游戏开始时,它会从队列的前面移除。
有了这个决定,为什么您认为会有 100 万活跃玩家?
如果是因为你是一个有着远大梦想的初创公司,我强烈建议你需要专注于尽可能高效地解决你已知的问题。万一成功(说真的,你看过统计数据了吗?),你可以稍后扩展。只有解决真正的问题才能大大提高你成功的几率,从可怕到微不足道。 (我并不是要气馁。但创业梦想确实是获得疯狂返回的几率很低。你采取的每一项行动都应该着眼于提高几率。)
如果您是一家成熟的游戏公司,有充分的理由相信您会达到这些数字,请继续阅读。
我不应该提及的一个显而易见的注意事项是,您将希望以相对快速的语言实现性能关键位。例如,如果您主要使用 Python 编写,那么这篇文章很适合使用 Java、Go 或 C++ 编写。
接下来,第一个不能缩放的是玩家信息。所以分发那个。这样做会减慢“玩家是否适合游戏”检查。所以添加每个游戏锁定,并异步分发该计算。在放弃和创建新游戏之前限制您尝试进入游戏的努力程度。
下一个瓶颈是游戏匹配计算。因此,继续将“此处的新游戏”分发到多台机器。现在一个玩家出现了,得到一个要检查的中央游戏列表,开始检查它们。为避免瓶颈,玩家应随机排序等待游戏列表。
网络瓶颈是要求该列表。该列表大部分是只读的,因此您可以只使用 Redis 的复制实例。写入(用于新游戏和标记游戏开始)可以交给 master,读取可以根据需要分布在任意多台机器上。玩家将随机打一个 Redis 副本,得到一个列表,随机排序。
如果达到这种规模,我会感到震惊。如果您超过了它,我会将后续步骤(例如对 Redis 进行分片)留给您。
随机笔记。这是一个体面的面试问题。 “设计这个简单的东西。让它扩展。让它扩展更多。让它扩展更多。”如果你真的在寻找一个了解分布式性能的人,那是一个很好的测试。 (但前提是面试官能够分辨好坏答案。)
关于algorithm - 并行/集群中图形节点分组的有效算法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17362227/
我一直在为此而苦苦挣扎。我想插入一个图像,并将其“靠近”讨论该图像的文本,但是该页面上的文本将围绕图像环绕/流动。 我已将图像转换为eps格式。最初,我尝试使用图形环境(\begin {figure}
我在用户界面中创建了管理控制台,管理员可以在其中执行所有操作,例如创建、删除用户、向用户分配应用程序以及从用户界面删除用户的应用程序访问权限 我厌倦了使用 Microsoft 图形 API 和 Azu
我在用户界面中创建了管理控制台,管理员可以在其中执行所有操作,例如创建、删除用户、向用户分配应用程序以及从用户界面删除用户的应用程序访问权限 我厌倦了使用 Microsoft 图形 API 和 Azu
我想为计算机图形学类(class)做一个有趣的项目。我知道那里有很多文献(即 SIGGRAPH session 论文)。我对计算机图形学(即图像处理、3D 建模、渲染、动画)兴趣广泛。但是,我只学了
我试图在 MaterializeCSS 网站上创建一些类似于这个的图形,但我不知道它来自哪里,我查看了整个 MaterializeCSS 网站,它不是框架的一部分,我找不到在代码中他们使用的是什么 我
我有一个包含 1 到 6 之间的各种数字的 TextView ,每个数字在每一行上代表一次,例如 123456 213456 214356 ...... 我希望能够绘制一条蓝线来跟随单个数值在列表中向
我目前在 Windows 7 上使用 Netbeans 和 Cygwin,我希望用 C 语言编写一个简单的 2D 游戏。 我设法找到的大多数教程都使用 Turbo C 提供的 graphics.h,C
亲爱的,我正在尝试将 kaggle 教程代码应用于 Iris 数据集。 不幸的是,当我执行图表的代码时,我只能看到这个输出而看不到任何图表: matplotlib.axes._subplots.Axe
我需要加快我正在处理的一些粒子系统的视觉效果。令人眼前一亮的是添加混合、积累以及粒子上的轨迹和发光。目前我正在手动渲染到浮点图像缓冲区,在最后一分钟转换为无符号字符,然后上传到 OpenGL 纹理。为
在研究跨网络的最短路径算法时,我想生成网络图片。我想代表节点(圆圈)、链接(线)、遍历链接的成本(链接线中间的数字)和链接的容量(链接线上它代表的节点旁边的数字)在这张图中。是否有任何库/软件可以帮助
尽管我已将应用程序从库添加到 Azure AD,但我无法看到何时尝试提取数据。但我可以看到添加的自定义应用程序。就像我添加了 7 个应用程序一样; 2 个来自图库(Google 文档、一个驱动器)和
因此,我正在构建一个系统,该系统具有“人员”,“银行帐户”和“银行帐户交易”。 我需要能够回答以下问题: “将所有与1/2/3度有联系的人归还给特定的人”, “返回年龄在40岁以上的所有人” “从德国
我在 JFrame 构造函数中有以下简单代码 super(name); setBounds(0,0,1100,750); setLayout(null); setVis
(这是java)我有一个椭圆形,代表一个单位。我希望椭圆形的颜色代表单位的健康状况。因此,一个完全健康的单位将是全绿色的。随着单位生命值的降低,椭圆形开始从底部填充红色。因此,在 50% 生命值下,椭
我目前正在开发一个学校项目。我们必须制作一个Applet,我选择了JApplet。由于某种原因,我用来显示特定字符串的面板将不会显示。这里可能有什么问题?请指出我正确的方向。另外,我看了一些教程,
我正在尝试创建一个 Simon game 。我正在编写游戏程序,但遇到了问题。我希望程序从队列中读取游戏中之前存在的所有值,并以正确的顺序将它们的颜色变为闪烁(我选择将它们变为灰色,然后在第二秒后恢复
我正在尝试创建一个框架,该框架在同一框架的顶部有一个图形面板(通过布局),在其下方有一个按钮/标签面板。到目前为止,我似乎已经能够将它们放在同一个框架上,但与按钮/标签面板相比,图形面板非常小....
我用 Java 编写了一个解决数独问题的代码,并使用 Java Applet 来设计它。现在,我尝试使用 Java Swing 使其看起来更好,并添加一些功能,例如“保存”数独板等。不幸的是,我对 J
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我现在尝试了 8 个多小时来解决这个问题,但无法弄清楚,请帮助找出我的代码有什么问题。 int main() { int gd = DETECT, gm; float ANGLE =
我是一名优秀的程序员,十分优秀!