- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
给定一个有 4 行和 N
列的棋盘。矩阵中的每个单元格都有一个值。给定需要放置在棋盘上的 2N
个标记(每个标记在一个单元格上),因此矩阵单元格中所有值的总和将尽可能大(最大值)。
放置 token 的限制是两个 token 不能水平或垂直相邻。
您不必放置所有的 2N
标记。
一列中有八种合法的标记方式,所以我定义了 8 个大小为 N
的数组,每个数组描述一个选项。
无论如何,使用动态规划,我需要为问题建立一个递归方程。
我想到了:
A(i,j) = max { A(i,j) , A(i,j) + max { A(i-1,j-1) , ... , H(i-1,j-1) } } , B(i,j) = .... , H(i,j) = ...
当A
是第一个数组,H
是第8个数组时。
现在,我不认为我的递归方程是好的。即使是,我也不知道如何将条件(两个标记不能水平或垂直相邻)添加到递归方程中。
有人可以帮忙吗?
最佳答案
是的,您有 8 种可能的方式在列中放置标记:
A B C D E F G H
e * * *
m * *
p * *
t * * *
y
现在,您只能在其他列之后放置特定的列。例如:
A
可以是任何列的邻居,A
可以是自己的邻居,B
可以是 C
和 G
的邻居,但不能是另一个 B
或F
或 H
,H
只能是A
、C
或D
等的邻居需要注意的一件事是,如果给定的列与 F
和 G
相邻,则 A
会很有用。
所以我们有一个(无向)图:
A B C D E F G H
A + + + + + + + +
B + - + + + - + -
C + + - + + + - +
D + + + - + - + +
E + + + + - + - -
F + - + + + - + -
G + + - + - + - -
H + - + + - - - -
以上是关联矩阵。
之后,我们将 A(i)
定义为如果 i th
,我们可以从前 i
列获得的最大可能总和列以类型 A
标记放置结束。 B
、C
、...、H
也是如此。
然后你有一个递归公式:
X(i+1) = {max Y(i) where X and Y can be neighboring columns} +
{sum of the cells in the i+1 column for placement X}
这里 X
遍历所有可能的位置 A
, B
, C
, ..., H
.
初始值为A(0) = 0, B(0) = 0, ..., H(0) = 0
。
最终答案是max{ A(N), B(N), C(N), D(N), ..., H(N) }
。
注意:
以上是解决方案,或者思路,实现可以不同。例如,您可以对所有内容进行硬编码(假设 Board[i][j]
是放置在棋盘上的值,索引从 0
开始):
F(i+1) = max{ A(i), C(i), E(i), G(i) } + // This is from the matrix above
Board[0][i+1] + Board[2][i+1] // This is from the definition of F type column
并且每个字母都相似。您不必将关联矩阵作为程序中的真实实体,只需在构造表达式时将其牢记在心即可。
关于algorithm - 跳棋板 - DP,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16495739/
我们将 Azure Boards(与敏捷流程相关的项目)定义为“功能”>“史诗”>“任务”>“用户故事”。 在我们的Azure Boards(Boards >Board)中,它仅显示Epic和Feat
我正在编写一个 C++ 井字游戏,这是我目前拥有的: #include using namespace std; int main() { board *b; b->draw();
这是一个足够简单的问题。 看完documentation for ion-pane它指出: A simple container that fits content, with no side eff
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 可以用事实和引用来回答它. 4年前关闭。 Improve this
我正在用 javascript 对 arduino 开发板进行编程。我正在尝试使用 johnny-five 库连接多个 arduino 板。我关注了johnny-five documentation我
在我的 Java 类(class)中,我们正在学习《Java 基础知识》一书的第 4 章。我正在做项目 4-11,它是一个黑色和红色的棋盘格,但是我得到随机颜色,我试图按照本书教我们使用 ColorP
我正在制作一个数独板 GUI,它应该看起来像这样 http://www.sudoku.4thewww.com/Grids/grid.jpg 由于某种原因,它只显示最后一个 3*3 板。如果有人能告诉我
我正在开发一款带有二维阵列(游戏板)的新游戏。每个单元格/图 block 都有一定数量的点。 我想实现的是一个算法能找到核心最高的最短路径。 所以我首先实现了 Dijkstra 算法(下面的源代码)来
更新:(2015-10-16)[已解决!]-使用trigger()并通过slice()限制为50个引脚固定。 非常感谢Abhas Tandon通过提供使用 $(this).trigger('click
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 7年前关闭。 Improve this questi
var size = 8; var board = ""; for (var y = 0; y x= (x+y) % 2 = 关于javasc
我正在制作一个简单的游戏,需要我创建一个由用户定义大小的棋盘。 我一直在编写一个函数,该函数应该返回我将在我的游戏中使用的棋盘(矩阵),但我似乎无法让它工作。 我尝试使用嵌套的 for 循环方法在 m
我正在尝试让板模板引擎与 express.js 一起工作。我最初的尝试是这样的: app.register('.html', { compile: function (str, options
我正在测试 Azure Boards Rest API。我目前可以成功创建、删除和获取项目,但我似乎无法在列之间移动它们。 这是我的要求https://{{AzureBoardsToken}}@{{A
我想用 trello api 归档一个板/列表,但我找不到解决方案。 与 https://trello.com/docs/api/list/#post-1-lists-idlist-archiveal
我上传了 sketch到一个 Arduino Uno,它的循环是这样的: void loop(){ Serial.println("Hello, World!"); } 所以,现在,我无法再上
我想要进行一个查询,显示结构 Epic -> 功能 -> 发布 -> 用户故事 -> 任务,以及特定迭代路径下的所有待处理任务 我尝试使用工作项树,但它只显示到 mu 用户故事 我的 Azure De
我在 python 中使用来自 Opencv 的 Charuco 标记。我之前使用的是 Aruco 开发板,我可以选择创建一个带有 id 偏移量(例如:偏移量为 40)的开发板。 from cv2 i
我不知道如何将另一个 View 中的辅助 Anchorpane 设置到主 View 的边界(在 fxml 代码中,它将是名为 holderPane 并且有灰色区域),这样当窗口展开时,它也会随之拉伸(
如何使用包含列、行和堆栈(包含 4、3、2、1)的 3D 通用数组制作一 block 板。 这是我声明的: private int row, col, stack; int[][][] array3D
我是一名优秀的程序员,十分优秀!