- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我完全被算法困住了,我需要一些帮助。
我有一个视频游戏,我有很多 Tuple<MatchId,PlayerId>
(约 1 亿)。所有这些元组都在 Mysql 数据库中,但如果需要可以导出到文本文件。
在这场比赛中,所有比赛都有 9 名球员。我想找到经常一起比赛的球员组,也就是说谁一起至少打了 10 场比赛,我想要这个比赛次数。
目前我的解决方案如下:我首先将这些元组分组为 Tuple<MatchId, Collection<PlayerId>>
因此,该集合有 1 到 9 个玩家。
然后,对于subgroupSize
2 到 9 之间:对于列表的每一行,我生成了大小为 subgroupSize
的所有子组。 ( maximum=126
对于 subgroupSize=5
)。
然后我创建另一个列表 Tuple<MatchId, Subgroup>
.然后我按子组对第二个列表进行分组,然后进行过滤并得到此 subgroupSize
的结果.
问题是,对于 subgroupSize
=5,我将有我的第二个列表,它的大小是第一个列表的 126 倍,过滤前大约有 10 亿行...
所以,我想知道您是否有更好的解决方案可以提出:)
谢谢你们,祝你们有美好的一天!
最佳答案
这是一个可以在 MySQL 中实现的方法。这个想法是采用迭代方法。建立一个 2 人组合表,然后是 3 人组合等等。保留中间表并对其进行适当索引。
首先,创建一个至少参加过 10 场比赛的球员列表:
create table players1 as
select t1.playerid
from tuples t1
group by t1.playerid
having count(*) >= 10;
对于成对的玩家:
create table players2 as
select t1.playerid as playerid1, t2.playerid as playerid2
from players1 p1 join
tuples t1
on p1.playerid = t1.playerid join
tuples t2
on t1.matchid = t2.matchid and
t1.playerid < t2.playerid join
players1 p2
on t2.playersid = p2.playersid
group by t1.playerid, t2.playerid
having count(*) >= 10;
这里的想法是 players1
表被用作 tuples
表的过滤器。
然后您可以对后续表格重复此过程。
老实说,我不确定这在 MySQL 中的效率如何。这在很大程度上取决于球员的数量以及参加过 10 场或更多比赛的球员的数量。
关于mysql - 如何找到经常一起玩的玩家组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20339289/
我正在尝试创建一个数据库来处理我在 Play 中的任务!框架。 这是我所拥有的: 在build.sbt中: libraryDependencies ++= Seq( jdbc, cache,
在我的游戏中定义一个表单!当编译器吐出这个奇怪的错误时 Controller :重载方法值映射与替代:...[一堆废话]...Error occurred in an application invo
我的应用程序有问题,@Max约束注释。 我的 Controller 方法定义如下: public static void save(@Required @Max(255) String content
我想创建一个像这样的标签: #{some_tag entity:user, field:'name'} 并期望它通过使用如下表达式生成带有用户名的输出: ${_entity._field} 我知道这行
我创建了一些 Model 对象来代表一家拥有多个客户的公司,以及一个由公司和客户组合以及多个发票行组成的发票对象。我创建了以下模型对象: @Entity public class Company ex
Playframework 现在是 typesafe-stack 的一部分。 那么,如果我要使用像主要语言一样的 Scala ,我现在应该下载什么? TypsafeStack 还是 PlayFrame
在玩!如果你这样称呼: void method() { User u = User(); u.name = "bob"; u.save(); while(true){/* endless loop *
我正在 Play 中构建一个应用程序!包含大量我想跟踪更改的数据的框架。在企业解决方案中,我可能会使用数据库触发器将更改复制到历史表中以跟踪这些更改。我不熟悉 Play!/JPA 中的类似范例,但也许
我一直在学习JavaScript技能,但是遇到一个问题,当单击此处是我的代码时,音频没有被播放。 Your browser does no
我想实现在某些模型保存后在表中插入一行的行为。我当前的解决方案简而言之是:(这只是我的代码示例,因此请不要评论数据库或描述符模型的正确性)。 我有一个监听器,用于在更新/插入实体上插入行为行 Desc
如何使我的模型类字段独一无二?例如。如果已经登录,我想为用户显示正确的消息。我必须自己编写验证检查并使用它,或者可以使用 JPA @UniqueConstraint? 最佳答案 我是这样做的: @En
我使用的是 Play 1.2.1。我想对我的用户密码进行哈希处理。我认为 Crypto.passwordHash 会很好,但事实并非如此。 passwordHash 文档说它返回 MD5 密码哈希值。
我一直在研究戏剧!框架模块并希望扩展它,添加一些功能。我发现了一个从Enhancer(play.classloading.enhancers.Enhancer)扩展的类,但不明白为什么Play!采用了
我使用的是 Play Framework 1.2.5。我有几个与 NAme 和 Age 字段相关的验证。年龄验证无法正常工作。即使年龄大于 18 岁,我也会收到错误消息。 下面是action方法中的验
我使用的是 Play Framework 1.2.5。两者有什么区别: @{Application.render()} 和 @Application.render() 第一个最好用在表单 Action
我是新来的!我被一些总是有错误的表格所困扰。即使所有字段都已填写,我也无法弄清楚问题是什么。 路线 GET /products/ controllers.Pr
我显示可编辑的数据库表行的列表。我想允许用户编辑显示表中的数据并同时保存所有更新。我应该如何取回 Controller 的更新列表? 最佳答案 由于 Play 可以绑定(bind)到 POJO,也可以
那么,假设我从 Controller 异步启动一个作业,然后渲染一些模板。 MyJob job = new MyJob(); job.doJob(); render(); 我的工作看起来像: 导入 p
当前使用的 Play Framework 为 2.0.4。当我尝试使用此命令升级到 2.6.21 时: addSbtPlugin("com.typesafe.play"% "sbt-plugin"%
我目前正在与 Play 合作!框架和看来日志记录只适用于游戏!仅但对于具有 LOGGER 初始化的类不起作用。 这是 logback.xml ${application.hom
我是一名优秀的程序员,十分优秀!