- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
基本上,我试图用C语言实现一个算法,它可以用右手或左手的规则来求解迷宫。我在一个文件里看到一个像这样的三角形迷宫:
我已经实现了解析文件并将迷宫加载到动态2d数组中的函数。根据数组中的值,我可以判断每个字段是否有右边框、左边框和垂直边框(根据字段的位置,上边框或下边框)我也被告知起始点的坐标(即,在这个特定例子中的6,1)和跟随的初始边界(即底部),当然,是否使用右手或左手规则来找到出口。
我应该列出通向出口的字段的坐标。我基本上已经实现了所有必要的函数来解析和检查迷宫的有效性,但是我并不完全理解如何在算法中使用右手和左手规则。我希望这是足够的信息,以了解我正在努力做什么。我不一定需要特定的代码,我只需要了解如何实际进行这项工作。
谢谢。
最佳答案
让我们用三角形迷宫细胞来表述右手法则。假设我们通过穿过单元格的底边进入单元格,如下图中的灰色箭头所示。
右手规则告诉我们要把右手放在墙上当我们进入牢房时,墙在哪里?
在上面的第一个例子中,右边没有墙。我们右边一定有堵墙,所以我们想一直向右拐,直到撞到它为止。在三角形迷宫中右转意味着顺时针旋转60度,跨过三角形的边缘进入相邻的细胞。
在第二种情况下,当我们进入牢房的时候,右边就有一面墙。我们想让这堵墙保持在我们的右边,所以我们向左拐,朝着那个方向走到相邻的牢房。
在第三种情况下,两边都有墙我们必须转身离开牢房我们将通过反向移动返回到上一个单元格,所以右边的墙这次将是三角形的另一条边。
为了遵循左边的规则,我们在上图的镜像上使用类似的推理。
接下来,我们需要网格单元的数值表示。有多种方法可以对单元格和边进行编号。一种可能性如下图所示。每个三角形的边编号为0、1、2左边是三角形的两个方向,显示每个方向的边编号中间是每个三角形方向的八种可能的墙配置右边是每个墙配置的十进制和二进制表示,使用边号从右到左索引二进制数字,即从最低有效数字到最高有效数字。
使用这个编号方案,问题中显示的迷宫可以用以下文本表示。第一行包含网格中的行数和列数第二行描述了我们的起点:行号、列号、交叉边其余行包含单元格描述。
6 7
6 1 2
4 2 1 1 5 0 3
4 1 2 0 2 0 1
4 0 1 0 1 3 4
4 2 7 4 0 1 1
6 4 1 1 6 4 2
2 2 6 0 2 2 6
0
和column
0
中这意味着如果我们有一个名为
maze
的二维整数数组,我们将左上角的单元格称为
maze[0][0]
。
r
和列索引
c
,使用基于零的编号,让我们从
r
和
c
的奇偶性计算出三角形的方向。如果它们具有相同的奇偶性,也就是说它们都是奇数或者都是偶数,则三角形指向下方否则,它指向上实现这一点的一个简单方法是计算
(r+c)%2
,如果平价相同,则计算
0
,如果平价不同,则计算
1
。
moves[2][3][3] = {
{ {-1, 0, 1}, {0, 1, 2}, {0, -1, 0} },
{ {0, 1, 2}, {1, 0, 0}, {0, -1, 1} } };
0
,向上三角形
1
。第二个索引是我们要穿过的边的编号,使用我们要离开的三角形的边编号。第三个索引用于查找上面列出的三条信息。
5
、column
0
开始。总和奇偶性是
1
,表示一个向上的三角形。我们越过了边缘因此,我们看
0
。结果信息是
maze[1][0]
,告诉我们在新的单元格中:
{0, 1, 2}
。
0
。
#include <stdlib.h>
#include <stdio.h>
int **maze, row_num, col_num,
moves[2][3][3] = { /* moves[orientation][edge] == {dr, dc, crossed} */
{ {-1, 0, 1}, {0, 1, 2}, {0, -1, 0} },
{ {0, 1, 2}, {1, 0, 0}, {0, -1, 1} } };
void go(int r, int c, int crossed, int turn) {
int edge, *move;
while (1) {
if (r < 0 || r >= row_num || c < 0 || c >= col_num) {
printf("out\n\n"); /* We've left the maze. */
return;
} /* Increment the indices for external display. */
printf("%d %d\n", r+1, c+1);
edge = crossed; /* We'll consider the crossed edge last. */
while (1) { /* Turn and look for an open edge. */
edge = (edge+turn+3)%3;
if ((maze[r][c] & (1 << edge)) == 0) {
break;
}
}
move = moves[(r+c)%2][edge];
r += move[0]; /* After looking up the move, update the */
c += move[1]; /* cell position and the edge number. */
crossed = move[2];
}
}
int main() {
int r_start, c_start, crossed_start, r, c;
scanf("%d %d", &row_num, &col_num);
scanf("%d %d %d", &r_start, &c_start, &crossed_start);
--r_start; /* We decrement the cell indices because */
--c_start; /* they are zero-based internally. */
maze = (int **) malloc(row_num*sizeof(int *));
for (r = 0; r < row_num; ++r) {
maze[r] = (int *) malloc(col_num*sizeof(int));
for (c = 0; c < col_num; ++c) {
scanf("%d", &maze[r][c]);
}
}
printf("\nRight-hand rule:\n");
go(r_start, c_start, crossed_start, -1);
printf("Left-hand rule:\n");
go(r_start, c_start, crossed_start, 1);
return 0;
}
关于c - C迷宫求解算法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27347471/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!