- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我玩Dwarf Fortress游戏。对我来说主要的挑战是有效地设计堡垒的布局。这意味着,每个行业流应尽可能密集,以尽量减少行进距离。
食品行业就是一个例子 .每个灰色椭圆代表一座建筑物。每个白色矩形代表来自建筑物的产品。
我的目标是找到一种算法,该算法可以将建筑物分布在 2D 网格上,使这些建筑物之间的距离从它们的连接方式来看是最小的。这意味着 fishery
和 loom
可以相距很远,但 loom
和 farmer's
应该尽可能靠近。
目前我考虑过使用一些现成的软件来模拟布局,但是一些算法提示就可以了。
目前我正在考虑一些力导向算法,但我不确定离散网格要求。
问题的形式化:是否存在适用于离散坐标的 Force Draw Graph 算法?
更新:我找到了 Force draw algorithm 的实现在 AS3 中(网络也包含 JS 版本)。我将尝试将其转换为离散版本。但我怀疑它是否会起作用...
更新 2:评论中要求进行一些进一步的限制。他们来了:每栋建筑占据虚拟网格上的单个单元格。建筑物可以位于相邻的单元格上。建筑物不能堆叠/重叠。(PS:在游戏中,每个建筑都有固定的尺寸,通常是 3x3,但我想让问题更笼统,以允许更多的方法)。
最佳答案
您几乎是在尝试解决平面规划问题的一个实例,在该实例中您试图最小化总“连接”长度。大多数这些问题都是 NP-hard 问题的实例,其中一些具有伪多项式运行时算法。
您可能感兴趣的一种特殊情况实际上可以在多项式时间内完全解决:如果您要放置的“盒子”或建筑物的相对位置提前已知。
有关如何解决此特殊情况的完整详细信息,请参阅 tutorial斯坦福几何编程,第 6 章,第 6.1 节,第一个示例,标题为“Floor planning”。另一个website还包括实现和解决问题的 matlab 代码(在第 8 章几何规划下。)
关于最小化顶点距离的算法 - Dwarf Fortress,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21311166/
谁能帮我写一个程序,它可以读取 DWARF 文件并给我文件名、行号和函数名的详细信息。 最佳答案 DWARF-2 和 DWARF-3 的规范在这里: http://dwarfstd.org/dwarf
XCode 支持此build设置的这 2 个值: build设置 > 构建选项 > 调试信息格式。 谁能解释一下区别? 最佳答案 不同之处在于,对于带有 dSYM 文件的 DWARF,您的存档 app
我想知道使用属性 DW_AT_location 进行调试。它是 dwarf 指定用于调试的属性之一,但无法真正理解它到底代表什么。以及当我们编译代码时应该什么时候发出这个属性。 最佳答案 来自 DWA
好的,我已经使用 Linux Dwarf ldw 库将 backtrace_symbols 输出转换为源代码和行号,但遇到了障碍。 backtrace_symbols 给出内存中的偏移量,在用作 Dw
考虑以下矮人代码示例 - : Abbrev Number: 1 (DW_TAG_compile_unit) DW_AT_producer : (indirect string, o
warning: invalid DWARF generated by the compiler: DIE 0x000629bb has multiple AT_decl_line attribute
我玩Dwarf Fortress游戏。对我来说主要的挑战是有效地设计堡垒的布局。这意味着,每个行业流应尽可能密集,以尽量减少行进距离。 食品行业就是一个例子 .每个灰色椭圆代表一座建筑物。每个白色矩形
对于 C/C++ 源文件中的任何元素,我希望能够在其编译的可执行文件中确定相应的内存位置。通过调试进行编译并使用生成的 DWARF 信息对实现这一目标大有帮助,但离我的目标还差得很远。 GCC 生成的
所有, 有没有工具可以检查文件的 DWARF 版本?像这样的东西: $ dwarf_tool binary_name 4 最佳答案 在Linux环境下?如果你安装了 GCC,你应该有 readelf可
我有一个通过内存跟踪程序执行的应用程序。我尝试使用 readelf --debug-dump=decodedline获取内存地址/行号信息,但我看到的内存地址通常与该转储给出的内存地址不匹配。我写了一
GCC 在其 DWARF 调试信息(使用 -g 编译时)中包含用于生成目标文件的源文件的路径。 然而,GDB的search rules意味着我必须使用鲜为人知的 set subsitute-path如
我试图将我对“DWARF”与“DWARF with dSYM file”调试信息格式的理解映射到我在不同 iOS 构建配置的崩溃信息中看到的内容。 我试图解决一个问题,即默认情况下不会对使用调试配置的
如何通过 DWARF 的引用获取我的变量地址? 例如我们有下一个结构: struct sub_struct { int a, b; sub_struct(int a, int b) :
我有一个 ARM 二进制文件,我需要准确找到其函数序言结束和尾声开始的地址。换句话说,我需要函数体的边界。例如,如果我有一个函数,其程序集类似于: 0x00000320 : push {r
有没有一种简单的方法可以让 Linux 进程访问它自己的 DWARF 调试信息?我有一个进程想要将一个特定编译单元的 DWARF 信息转储到日志文件中。 这是为了简化一些物流。我有包含原始 C 结构的
尝试构建时,我在 Xcode 4 中遇到以下错误: libIOSCoreSDK.a(Logging.o) object file doesn't contain DWARF debug informa
例如: : Abbrev Number: 1 (DW_TAG_compile_unit) DW_AT_producer : (indirect string, offset: 0
有没有办法将调试信息从 binutils 的 DWARF 格式(例如,由 Cygwin 上的 GCC 发出)转换为 Microsoft PDB(由 Visual Studio 使用)? 最佳答案 cv
在 perf record --call-graph dwarf 生成的回溯中由 perf script 打印,我一直在为大约 5% 的调用堆栈获取错误的地址,即展开失败。一个例子是 my_bin 7
我正在尝试从 DWARF 信息中获取有关调用约定的信息。更具体地说,我想了解哪些寄存器/堆栈位置用于将参数传递给函数。我的问题是,在某些情况下,我从 DWARF 转储中获得了某种错误的信息。我使用的示
我是一名优秀的程序员,十分优秀!