转自:http://blog.csdn.net/holymaple/article/details/8636234

由于迷宫的设计,老鼠走迷宫的入口至出口路径可能不止一条,如何求出所有的路径呢?

解法:求所有的路径困哪起来复杂但其实更简单,只要在老鼠走到出口时显示经过的路径,然后退回上一格重新选择下一个位置继续递回就可以了,比求出单一路径更简单,程序只需要做一点点修改就行了。

C++版:

  1 /*
2 *内容;老鼠走迷宫II
3 *时间;3/01/2013
4 */
5
6 #include <stdio.h>
7
8 // 注:二维数组,根据编译器采取的策略不同,起点或终点位置会有所不同
9 // 既编译器可能采取“按行优先”或者是“按列优先”这两种不同的策略
10
11 //终点位置
12 #define END_I 7
13 #define END_J 1
14
15 //迷宫为全局变量
16 //初始化迷宫,用2来表示墙壁、1表示路径
17 int g_maze[9][9] = { {2, 2, 2, 2, 2, 2, 2, 2, 2},
18 {2, 0, 0, 2, 0, 2, 0, 0, 2},//起点位置(1,1)
19 {2, 0, 2, 0, 0, 0, 0, 2, 2},
20 {2, 0, 0, 0, 2, 2, 0, 0, 2},
21 {2, 2, 2, 0, 0, 0, 2, 0, 2},
22 {2, 0, 0, 0, 2, 0, 2, 0, 2},
23 {2, 0, 2, 2, 0, 2, 0, 0, 2},
24 {2, 0, 0, 0, 0, 0, 0, 2, 2},//终点位置(7, 1)
25 {2, 2, 2, 2, 2, 2, 2, 2, 2},
26 };
27
28 bool g_sucess = false;//全局变量,用来确保是否到达终点。
29 int g_count = 0;//全局变量,用来统计路径的数量
30
31 //打印迷宫
32 void printMaze(int *maze, int mazeWidth, int mazeHeight)
33 {
34 int mazeSize = 0;
35 //将传进来二位数组的长度相乘确保能够完全遍历完数组
36 mazeSize = mazeWidth * mazeHeight;
37 for (int i = 0; i < mazeSize; ++i)
38 {
39 if ( (i%mazeWidth) == 0)
40 {
41 printf ("\n");
42 }
43 if ( *maze == 2 )//2表示墙壁,墙壁用X表示
44 {
45 printf ("X");
46 }
47 else if ( *maze == 1 )//1表示走过的路径,用“.”表示
48 {
49 printf (".");
50 }
51 else if ( *maze == 3 )//终点位置打印笑脸
52 {
53 putchar(1);
54 }
55 else//0表示可走路径,用“o”来表示
56 {
57 printf ("o");
58 }
59 maze++;
60 }
61 printf ("\n\n");
62 }
63
64 void visit(int i, int j)
65 {
66 g_maze[i][j] = 1;
67 if ( (i==END_I) && (j==END_J) )
68 {
69 g_maze[i][j] = 3;//标记终点位置打印特别符号来区别路径
70 g_sucess = true;//表示至少找到一条路径
71 printf ("\n已经找到了第%d条路径:\n", ++g_count);
72 printMaze(&(g_maze[0][0]), 9, 9);
73 }
74 //向下走
75 if (g_maze[i][j+1]==0)
76 {
77 visit(i, j+1);
78 }
79 //向右走
80 if (g_maze[i+1][j]==0)
81 {
82 visit(i+1, j);
83 }
84 //向上走
85 if (g_maze[i][j-1]==0)
86 {
87 visit(i, j-1);
88 }
89 //向左走
90 if (g_maze[i-1][j]==0)
91 {
92 visit(i-1, j);
93 }
94 g_maze[i][j] = 0;//恢复改点
95 }
96
97
98
99 int main()
100 {
101
102 printf ("\t显示迷宫:\n\n");
103 printMaze(&(g_maze[0][0]), 9, 9);
104 visit(1,1);//把起点位置传进去
105 if ( g_sucess )
106 {
107 printf ("已找到出口,打印路径:\n\n");
108 }
109 else
110 {
111 printf ("没有找到出口!");
112 }
113 return 1;
114 }

老鼠走迷宫II的更多相关文章

  1. 老鼠走迷宫I

    转自:http://blog.csdn.net/holymaple/article/details/8582517 说明:老鼠走迷宫是递回求解的基本提醒,我们在二维阵列中使用2来表示迷宫墙壁,使用1来 ...

  2. noj电子老鼠走迷宫(深搜dfs)超时错误

    1042.电子老鼠闯迷宫 时限:1000ms 内存限制:10000K  总时限:3000ms 描述 有一只电子老鼠被困在如下图所示的迷宫中.这是一个12*12单元的正方形迷宫,黑色部分表示建筑物,白色 ...

  3. noj->电子老鼠走迷宫

    00 问题 描述: 有一只电子老鼠被困在如下图所示的迷宫中.这是一个12*12单元的正方形迷宫,黑色部分表示建筑物,白色部分是路.电子老鼠可以在路上向上.下.左.右行走,每一步走一个格子.现给定一个起 ...

  4. Java与算法之(5) - 老鼠走迷宫(深度优先算法)

    小老鼠走进了格子迷宫,如何能绕过猫并以最短的路线吃到奶酪呢? 注意只能上下左右移动,不能斜着移动. 在解决迷宫问题上,深度优先算法的思路是沿着一条路一直走,遇到障碍或走出边界再返回尝试别的路径. 首先 ...

  5. 老鼠走迷宫(2)输出所有路径(C语言)

    需求 有一个迷宫,在迷宫的某个出口放着一块奶酪.将一只老鼠由某个入口处放进去,它必须穿过迷宫,找到奶酪.请找出它的行走路径. STEP 1 题目转化 我们用一个二维数组来表示迷宫,用2表示迷宫的墙壁, ...

  6. 老鼠走迷宫(1)输出唯一路径(C语言)

    需求 有一个迷宫,在迷宫的某个出口放着一块奶酪.将一只老鼠由某个入口处放进去,它必须穿过迷宫,找到奶酪.请找出它的行走路径. STEP 1 题目转化 我们用一个二维数组来表示迷宫,用2表示迷宫的墙壁, ...

  7. (╭ ̄3 ̄)╭ 小希的迷宫II

    (╭ ̄3 ̄)╭ 小希的迷宫II TimeLimit: 2000/1000 MS (Java/Others)  MenoryLimit: 65536/32768 K (Java/Others) 64-b ...

  8. C语言动态走迷宫

    曾经用C语言做过的动态走迷宫程序,先分享代码如下: 代码如下: //头文件 #include<stdio.h> #include<windows.h>//Sleep(500)函 ...

  9. sdut 2449走迷宫【最简单的dfs应用】

    走迷宫 Time Limit: 1000ms   Memory limit: 65536K  有疑问?点这里^_ 题目描述 一个由n * m 个格子组成的迷宫,起点是(1, 1), 终点是(n, m) ...

随机推荐

  1. 《手把手教你》系列技巧篇(十)-java+ selenium自动化测试-元素定位大法之By class name(详细教程)

    1.简介 按宏哥计划,本文继续介绍WebDriver关于元素定位大法,这篇介绍By ClassName.看到ID,NAME这些方法的讲解,小伙伴们和童鞋们应该知道,要做好Web自动化测试,最好是需要了 ...

  2. 关于 .NET 与 JAVA 在 JIT 编译上的一些差异

    最近因为公司的一些原因,我也开始学习一些 JAVA 的知识.虽然我一直是以 .NET 语言为主的程序员,但是我并不排斥任何其它语言.在此并不讨论 JAVA .NET 的好坏,仅仅是对 .NET 跟 J ...

  3. 选择排序(selection_sort)——Python实现

      # 选择排序 # 作用:对给出的n个顺序不定的数进行排序 # 输入:任意数组A # 输出:按顺序排列的数组A # 时间复杂度 (n(n-1))/2 # 选择排序 # 第一趟:选择第一个元素,依次与 ...

  4. CSRF+XSRF+SSRF简单介绍

    CSRF 使用DVWA靶机,选择low级别,然后更改密码 伪造网页连接 http://localhost:8083/DVWA-master/vulnerabilities/csrf/?password ...

  5. 04.委托Delegation

    1. 基本了解 1.1 委托简述 官方文档 委托是一种引用类型,表示对具有特定参数列表和返回类型的方法的引用,用于将方法作为参数传递给其他方法,可将任何可访问类或结构中与委托类型匹配的任何方法分配给委 ...

  6. (1)用 if语句 区间判断

    /*此例子只做比喻演示*/ 1 #include <stdio.h> 2 int main() 3 { 4 5 int p; 6 scanf("%d",&p); ...

  7. 原生js 以ajax(post)的方式传json至php,并让php解析为数组

    如题. 比如要把一个json,如 json= {name:"John Rambo", time:"3pm"},,通过js ,传到一个php服务器 fwq.php ...

  8. 【剑指offer】65. 不用加减乘除做加法

    剑指 Offer 65. 不用加减乘除做加法 知识点:数学:位运算 题目描述 写一个函数,求两个整数之和,要求在函数体内不得使用 "+"."-"."* ...

  9. TCP文件上传实现

    TCP文件上传实现 服务端: package net.study; import java.io.*; import java.net.ServerSocket; import java.net.So ...

  10. configmap使用方法

    说明: kubernetes统一配置管理方案configmap,实现将配置文件从容器镜像中解耦,增强应用的可移植性.数据可直接注入pod对象中,为容器所使用,注入方式有挂载为存储卷和传递为环境变量两种 ...