xiangrikui336454 2014-02-28 03:24
浏览 956

迷宫求解 递归方法 求助大牛帮忙解答疑问

//此题目是迷宫求解问题,起点是[0][0]位置,要到达的位置是[N-1][N-1]
//traverse()此函数为什么就能完成了迷宫求解问题呢?
//maze_ret[i][j] = maze[i][j]; 此语句具体含义是什么?
//maze_ret[11][11];此数组的具体用处是什么?
//我认为函数会把所有的为0的数据全部置为3,但是为什么没有呢?

#include

int N;
int maze[11][11];
int maze_ret[11][11];
void traverse(int, int);

int main(void) {
int tc, T, i, j;

freopen("input.txt", "r", stdin);

setbuf(stdout, NULL);

scanf("%d", &T);
for (tc = 0; tc < T; tc++) {
    scanf("%d", &N);
    for (i = 0; i < N; i++) {
        for (j = 0; j < N; j++) {
            scanf("%d", &maze[i][j]);
        }
    }

    traverse(0, 0);

    for (i = 0; i < N; i++) {
        for (j = 0; j < N; j++) {
            printf("%d ", maze_ret[i][j]);
        }
        printf("\n");
    }
    printf("\n\n");

}

return 0;

}

void traverse(int x, int y) {
int i, j;

maze[x][y] = 3;
if (x == N - 1 && y == N - 1) {
    for (i = 0; i < N; i++) {
        for (j = 0; j < N; j++) {
            maze_ret[i][j] = maze[i][j];
        }
    }
}

if ((y < N - 1) && (maze[x][y + 1] == 0))
    traverse(x, y + 1);
if ((x < N - 1) && (maze[x + 1][y] == 0))
    traverse(x + 1, y);
if ((y >= 1) && (maze[x][y - 1] == 0))
    traverse(x, y - 1);
if ((x >= 1) && (maze[x - 1][y] == 0))
    traverse(x - 1, y);

}

  • 写回答

0条回答

    报告相同问题?

    悬赏问题

    • ¥15 如何在scanpy上做差异基因和通路富集?
    • ¥20 关于#硬件工程#的问题,请各位专家解答!
    • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
    • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
    • ¥30 截图中的mathematics程序转换成matlab
    • ¥15 动力学代码报错,维度不匹配
    • ¥15 Power query添加列问题
    • ¥50 Kubernetes&Fission&Eleasticsearch
    • ¥15 報錯:Person is not mapped,如何解決?
    • ¥15 c++头文件不能识别CDialog