- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我输入了这样一张 map :
int map_w = 40;
int map_h = 20;
char map[20][40] = {
{'c', 'c', 'c', 'c', 'n', 'n', 'n', 'n', 'n', 'n', 'n', 'n', 'n', 'n', 'c', 'c', 'n', 'n', 'n', 'c', 'c', 'c', 'c', 'c', 'c', 'h', 'h', 'h', 'h', 'h', 'h', 'c', 'c', 'c', 'c', 'c', 'n', 'h', 'n', 'n'},
{'n', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'n', 'n', 'c', 'n', 'n', 'c', 'c', 'c', 'c', 'c', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'n', 'c', 'n', 'n', 'h', 'h', 'n'},
{'c', 'c', 'c', 'c', 'n', 'c', 'n', 'n', 'c', 'c', 'h', 'n', 'n', 'c', 'n', 'c', 'c', 'c', 'c', 'c', 'c', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'c', 'c', 'c', 'c', 'c', 'c', 'h', 'h', 'n'},
{'h', 'h', 'h', 'c', 'c', 'c', 'c', 'c', 'c', 'h', 'h', 'n', 'c', 'n', 'n', 'h', 'h', 'h', 'h', 'n', 'c', 'c', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'c', 'c', 'c', 'c', 'c', 'c', 'n', 'h', 'h', 'n'},
{'h', 'h', 'h', 'h', 'c', 'c', 'c', 'n', 'c', 'c', 'h', 'c', 'c', 'c', 'c', 'h', 'h', 'h', 'h', 'n', 'c', 'c', 'c', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'c', 'c', 'c', 'h', 'h', 'h', 'h', 'h', 'h', 'h'},
{'h', 'h', 'h', 'h', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'n', 'n', 'n', 'c', 'h', 'h', 'h', 'c', 'c', 'c', 'c', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'n', 'c', 'h', 'h', 'n', 'h', 'n', 'h', 'n'},
{'n', 'h', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'n', 'n', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'h', 'h', 'h', 'h', 'h', 'h', 'n', 'h', 'h', 'n', 'h', 'h', 'h', 'h'},
{'c', 'c', 'n', 'c', 'n', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'n', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'n', 'n', 'h', 'h', 'h', 'p', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h'},
{'c', 'c', 'n', 'c', 'n', 'c', 'c', 'n', 'n', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'n', 'c', 'c', 'c', 'c', 'n', 'c', 'c', 'c', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'c', 'h', 'h', 'h', 'h', 'n', 'h'},
{'c', 'c', 'c', 'n', 'c', 'c', 'c', 'n', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'h', 'c', 'c', 'c', 'c', 'c', 'n', 'n', 'c', 'c', 'c', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'n', 'h', 'p', 'h', 'h', 'h'},
{'c', 'c', 'c', 'n', 'c', 'c', 'c', 'c', 'c', 'n', 'c', 'c', 'c', 'c', 'h', 'h', 'c', 'n', 'n', 'n', 'c', 'c', 'c', 'd', 'c', 'c', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'c', 'h', 'h', 'h', 'h', 'h', 'h'},
{'c', 'c', 'n', 'c', 'c', 'n', 'n', 'c', 'c', 'c', 'c', 'h', 'c', 'h', 'h', 'n', 'n', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'n', 'h', 'h', 'h', 'h', 'n', 'h', 'n', 'c', 'h', 'h', 'h', 'h', 'h', 'h'},
{'c', 'c', 'n', 'n', 'c', 'n', 'c', 'n', 'c', 'n', 'c', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'n', 'h', 'n', 'c', 'h', 'h', 'n', 'h', 'n', 'h'},
{'n', 'c', 'c', 'n', 'c', 'n', 'n', 'n', 'c', 'n', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'n', 'c', 'c', 'n', 'c', 'h', 'h', 'h'},
{'n', 'c', 'n', 'n', 'c', 'n', 'c', 'n', 'c', 'p', 'h', 'h', 'h', 'n', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'h', 'n', 'c', 'c', 'c', 'n', 'c', 'h', 'h', 'h'},
{'n', 'n', 'c', 'c', 'c', 'c', 'n', 'n', 'c', 'c', 'c', 'c', 'h', 'h', 'c', 'h', 'n', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'h', 'c', 'c', 'c', 'n', 'n', 'c', 'c', 'n', 'n', 'h', 'h', 'n'},
{'n', 'n', 'n', 'c', 'c', 'n', 'n', 'n', 'c', 'h', 'h', 'c', 'h', 'n', 'c', 'h', 'n', 'n', 'c', 'n', 'n', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'n', 'c', 'c', 'c', 'n', 'n', 'c', 'c', 'n', 'h', 'h', 'n'},
{'n', 'n', 'n', 'n', 'n', 'n', 'c', 'c', 'c', 'h', 'h', 'h', 'h', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'n', 'c', 'c', 'c', 'c', 'n', 'n', 'c'},
{'n', 'n', 'c', 'c', 'n', 'c', 'n', 'n', 'h', 'h', 'h', 'h', 'h', 'c', 'c', 'n', 'c', 'h', 'h', 'h', 'h', 'h', 'h', 'c', 'n', 'n', 'n', 'c', 'n', 'n', 'n', 'c', 'n', 'n', 'n', 'c', 'n', 'n', 'c', 'n'},
{'c', 'c', 'c', 'c', 'n', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'c', 'n', 'n', 'c', 'n', 'c', 'c', 'c', 'c', 'c', 'c', 'n', 'n', 'n', 'c', 'n', 'n', 'c', 'n', 'c', 'c', 'n', 'n', 'n', 'n', 'n'}
};
这是 map 的图像:
数组中的字符对应于每个正方形,也就是说,灰色是 h,这是一 block 我不能走的石头。棕色是长度为 1 的正常路径 (c) 绿色是长度为 2 的森林 (n)
然后 d 是龙,p 是公主,我必须先找到到龙然后到公主的最短路径,然后返回准确的最短路径..
所以我的第一个问题是,是否有某种方法可以将此输入输入一些修改后的 Dijkstra、Bellman-Ford 或其他算法?或者我必须首先为每个正方形建立一个连接,从正方形 1,2 我可以转到 1,1 并且长度为 2,然后到 2,2 并且长度为 2,或者我可以简单地以某种方式运行算法双数组??
问题 2 你建议使用哪种算法?我想到了 Bellman Ford,虽然我没有负方 block ,但我需要返回确切的路径,这非常容易,这要归功于在 Bellman Ford 中维护的数组 pi,但我愿意接受任何建议,因为我刚刚进入图论。
最佳答案
我建议你仔细看看A* .
这是一种简单而有效的查找路径的方法,尤其是在二维网格中。
关于c - Dijkstra,Bellman Ford 在双阵列 map 上的应用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20147378/
我最近在学习图形算法,在我的大学里我们被教导,Bellman-Ford 的结果是一个所有节点到所有其他节点的距离表(所有对最短路径)。但是我不明白这个算法是如何实现的,并试图通过观看 YouTube
我用队列实现了 Bellman - Ford 算法的解决方案,并将其性能与 Dijkstra 算法进行了比较。他们非常接近,这让我感到惊讶,因为 Bellman - Ford 的复杂度是 O(NM)。
一 点睛 如果遇到负权边,则在没有负环(回路的权值之和为负)存在时,可以采用 Bellman-Ford 算法求解最短路径。该算法的优点是变的权值可以是负数、实现简单,缺点是时间复杂度过高。但是该算法可
我一直在尝试通过以下资源来了解 Bellman-Ford 的正确实现:1 & 2 如果我们已经知道给定的加权有向图不包含环(因此也没有负环),那么是否遵循 Bellman-Ford 算法的正确实现?
解决 UVA 的套利问题 http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&
我正在为 Coursera 上的“图上的算法”类(class)做练习,我必须实现 Bellman-Ford 算法来检测图是否有负循环,分别输出 1 和 0。我做了很多压力测试,我的实现工作正常,但它在
如何在 Bellman-Ford 算法中证明这一点: 如果没有负权重循环,则从源 s 到汇 t 的每条最短路径至多有 n-1 边,其中 n 是图中的顶点数。 有什么想法吗? 最佳答案 该陈述逐字逐句是
我正在为过去的一门课准备一套习题我应该实现Bellman-Ford算法,以便从源代码s,我必须找到以下内容: 如果无法从s访问节点(输出为*) 如果节点是可到达的,但是是负循环的一部分,因此没有最短路
Bellman-Ford算法用于解决有边数限制的最短路问题,且可以应对有负边权的图 其时间复杂度为O(nm),效率较低 代码实现: ?
这是我的代码: #include #include #define inf 99999999 #define vertex 5 #define edge 6 int main(){ int d
我尝试编写 bellman-ford 算法,但我发现它不起作用。问题是,我(和我问过的任何人)都找不到错误,我认为这一定很简单。起初它似乎是正确的,因为对于我使用它的每个示例,它都很好用,但对于一些更
在具有 V 个节点和 E 条边的有向图中,Bellman-Ford 算法将每个顶点(或者更确切地说,从每个顶点发出的边)松弛 (V - 1) 次。这是因为从源到任何其他节点的最短路径最多包含 (V -
因此,如果我尝试使用 Bellman Ford 算法找到最短路径,使用此方法来测试是否存在路径: public boolean hasPath(int v){ return distTo[v]
假设有一个有100-Vertexes 的有向图,例如V_1---> V_2 ---> ... ---> V_100 所有边的权重都是 1。我们想使用 Bellman-Ford 算法找到顶点 1 (V_
是否每个图都有边的顺序,以便在根据此顺序运行 Bellman-Ford 算法的单次迭代后,每个顶点都标有它到源的最短路径? 我很确定答案是肯定的,但我想不出能够找到边顺序的算法,谢谢 =] 最佳答案
我一直在搜索 Bellman-Ford 算法的空间复杂度,但是在 wikipedia Bellman-Ford Algorithm 上它说空间复杂度是 O(V)。在 this link它说 O(V^2
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
我不知道还有什么地方可以发布这个问题,我只想知道我是否正确地进行了跟踪。我得到了这张图 问题是: Show the trace of the Bellman-Ford algorithm on the
假设我们想使用 Bellman-Ford 来最小化 max_i x_i - min_i x_i 在变量 x_1, x_2, ... x_n 上(总共 n 个变量) 受到形式为 x_i - x_j <=
我正在尝试从 CLRS 实现 Bellman Ford 算法,它似乎在距离度量上随机溢出。我的代码如下: private void initSingleSource(Vertice source) {
我是一名优秀的程序员,十分优秀!