- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有一个游戏系统,可以表示为一个无向、未加权的图,其中每个顶点都有一个(相关)属性:颜色。就图形表示而言,游戏的目标是以尽可能少的“步骤”将其减少到一个顶点。在每一步中,玩家可以改变任何一个顶点的颜色,并且所有相邻的相同颜色的顶点都与之合并。 (请注意,在下面的示例中,我只是碰巧显示用户在整个游戏中只更改一个特定的顶点,但用户可以在每个步骤中选择任何顶点。)
我所追求的是一种方法来计算按照上述过程“打败”给定图形所需的最少步数,并提供这样做所需的具体 Action 。我熟悉寻路、BFS 和类似性质的基础知识,但我很难根据“最快路径”解决方案来解决这个问题。
我无法在 Google 上的任何地方找到同样的问题,甚至找不到封装该问题的图论术语。有没有人至少知道如何开始解决这个问题?谁能指出我正确的方向?
编辑 由于这个问题似乎真的很难有效解决,也许我可以改变我的问题的目的。有人能描述一下我什至会如何设置蛮力,广度优先搜索吗? (蛮力可能没问题,因为实际上这些图最多只有 20 个顶点。)我知道如何为普通链接图数据结构编写 BFS ......但在这种情况下它看起来很奇怪,因为每个顶点必须在其内部包含一个完整的图,并且搜索图中的下一个顶点必须基于可能在顶点内的图中进行的移动来生成。如何设置数据结构和搜索算法来实现这一目标?
EDIT 2 这是一个老问题,但我认为直截了本地说明游戏是什么可能会有所帮助。该游戏本质上是对Kami 2 for iOS的剽窃。 , 除了我的自定义拼图编辑器会自动找出最快的方法来解决你的拼图,而不是必须自己通过反复试验找到最短的移动数。我不确定 Kami 是否是一个完全原创的游戏概念,或者是否有一整类游戏都具有我不知道的相同“洪水填充”机制。如果这是一种常见的游戏类型,也许知道它的名称可以让我找到更多关于我正在寻找的算法的文献。
编辑 3 This Stack Overflow question似乎它可能有一些相关的见解。
最佳答案
直觉上,解决方案似乎是全局性的。例如,如果您采用更大的图,您首先选择的点将对直接邻居产生影响,直接邻居将对其邻居产生影响,依此类推。
听起来好像它与 map 着色问题属于同一类问题。不是因为颜色,而是因为本地选择对图表另一端的影响。在 map 着色中,你必须决定用什么颜色来绘制一个国家和它的邻国,这样两个接触的国家就不会有相同的颜色。第一组选择会影响后续迭代中是否有解决方案。
关于algorithm - 合并图的相邻顶点,直到以尽可能少的步骤留下单个顶点,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44077500/
目前,我在单击我的正文时打开一个新选项卡,但它将焦点更改为子窗口。但我想通过留下窗口来做到这一点,这样弹出窗口就不会被阻止,并且我可以将焦点放在当前窗口上。 以下代码当前正在运行 /** * For
我有一个带有线性渐变的 css 背景图像。 CSS 代码: .footer-about { display: flex; align-items: center; justif
在服务中包含以下代码(假设在快速端点上): async function (res, req, next) { const fetch = require('node-fetch'); awa
我正在使用 IImageList 和 SHGetFileInfo 为任何给定路径提取巨型图标。一旦我有了它,然后我使用 DrawIconEx 将 HICON 渲染到 HBITMAP 中,最终使用 GD
我有图表并计算了网络密度,现在我应该只保留具有最大权重的分支(网络密度的前 10%,例如 200 中权重最大的 20 个分支)。我找不到该怎么做? 最佳答案 这个问题有点令人困惑,因此,如果稍后出现更
我一直在尝试使用 jquery 创建一种效果,当您将鼠标移到一个 div 上时,整个 body 都会移动,并沿着它经过的点留下一条轨迹。我创建了一个可以使整个 body 移动的功能,但我找不到离开轨迹
我想在桌面上显示放大和缩小图标(控件),而仅在移动设备上浏览时显示 gps 图标。我正在使用这个 css https://unpkg.com/leaflet@1.1.0/dist/leaflet.cs
相关代码(索引为数组大小): typedef struct elemento { unsigned long linha; unsigned long coluna; doub
我有一个 div,因此当我单击时,它会切换为展开或缩回。它在所有浏览器上都运行良好,尽管有一点让我很感兴趣。在谷歌浏览器上,当它缩回时,它会在运动中留下细线。 www.rezoluz.com/logi
每当我的应用程序尝试通过调用 CreateDIBSection() 或使用 LR_CREATEDIBSECTION 标志调用 LoadImage() 来创建 DIB 部分时,它似乎都会成功返回。它返回
我想在 Protractor 测试中脱离 Selenium 控制流。 以下是我迄今为止遇到的步骤和问题: 1。逐个测试禁用它 我的第一个想法是使用 SELENIUM_PROMISE_MANAGER 以
我正在构建一个部署在 CentOS 7.2 上的 ASP.Net Core (netcore 1.1) 应用程序。 我有一个通过 System.Diagnostics.Process 调用外部进程(也
我正在为我的网站创建一个聊天小部件。用户将能够输入纯文本 - 没有 html。 为了消除 HTML 标记并允许用户使用“”,我正在接受他们的输入并在用户屏幕的输入上使用 strip_tags() 和输
我是一名优秀的程序员,十分优秀!