- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我在编程竞赛 ( Andrew Stankevich Contest 21 ) 中遇到了一个问题,这个问题是关于一个如下所示的游戏:
Nick and Peter like to play the following game [...]. They draw an undirected bipartite graph G on a sheet of paper, and put a token to one of its vertices. After that they make moves in turn. Nick moves first.
A move consists of moving the token along the graph edge. After it the vertex where the token was before the move, together with all edges incident to it, are removed from the graph. The player who has no valid moves loses the game.
图表已给出,现在的任务是针对给定的起始节点,如果两个玩家都玩得最好,则起始玩家是赢还是输。总结
由于该图是二分图,Nick(第一个玩家)总是会从左侧移除一个节点,而 Peter 总是会从右侧移除一个节点。
该图最多可以有1000个节点(每边最多500个)和50000条边,所以需要一个好的多项式时间算法(这里的时间限制是2秒来解决所有的起始位置,但我认为我们可以在不同的起始位置之间共享大量信息)。
我很确定这可以归结为某种顶点覆盖或打包问题,因为该图是二分图,但我找不到与这些问题相关的策略。
我知道一个特殊情况的解决方案:假设边有 n1 和 n2顶点,分别。如果有matching大小 min(n1, n2) 并且如果较小一侧的玩家开始,则存在获胜策略:他只是必须遵循匹配的边并自动获胜。
有什么想法吗?
最佳答案
命题 Nick(第一个玩家)从顶点v
开始获胜当且仅当该顶点属于给定图的每个可能的最大匹配。我们将分两步证明。
如果没有v
最大匹配,尼克输了。
实际上,由于匹配是最大的,因此不存在从 v
开始的增广路径。 .这意味着来自 v
的每条简单的奇数长度路径可以通过匹配的边缘来延长。就我们的问题而言,这意味着在 Nick 的每一步之后,Peter 都可以继续游戏。
如果没有v
就没有最大匹配, 尼克赢了。
考虑任何可能的最大匹配。从v
沿着这个匹配的边缘移动比如说,u
.现在,初始匹配减去边 u-v
是剩余图的最大匹配,不包括 u
.正如我们从第 1 步中了解到的,现在要移动的玩家(即彼得)不知所措。
至于实现,我们可以首先使用简单的算法(see here 作为示例实现)在 O(VE) 中构造最大匹配——原来通用名称是 Kuhn 的增广路径算法。
之后,您保持最大匹配并查看每个顶点。如果是顶点,说 v
, 当前不在匹配中,Nick 输了。如果是,则删除相应的边,比如 v-u
,从匹配中,禁止顶点v
暂时搜索u
的增广路径在 O(E) 中。如果你没有找到这样的路径,尼克赢了,你必须恢复你删除的边缘。否则,尼克又输了,新的最大匹配可以保持不变。总运行时间又是O(VE)。
关于algorithm - 解决图形游戏,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22618867/
我一直在为此而苦苦挣扎。我想插入一个图像,并将其“靠近”讨论该图像的文本,但是该页面上的文本将围绕图像环绕/流动。 我已将图像转换为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 =
我是一名优秀的程序员,十分优秀!