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

说明:老鼠走迷宫是递回求解的基本提醒,我们在二维阵列中使用2来表示迷宫墙壁,使用1来表示老鼠走过的行走路径,试以程序球场胡入口至出口的路径。

解法:老鼠的走法有上、下、左、右四个方向在每前进一格之后就选一个方向前进,无法前进时退回选择下一个可前进方向,如此在阵列中依序测试四个方向,直到走到出口为止,这是递回的基本题,请直接看程序应就可以理解。

C++版:

  1 /*
2 *内容;老鼠走迷宫I
3 *时间;2/16/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, 2, 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
30 //打印迷宫
31 void printMaze(int *maze, int mazeWidth, int mazeHeight)
32 {
33 int mazeSize = 0;
34 //将传进来二位数组的长度相乘确保能够完全遍历完数组
35 mazeSize = mazeWidth * mazeHeight;
36 for (int i = 0; i < mazeSize; ++i)
37 {
38 if ( (i%mazeWidth) == 0)
39 {
40 printf ("\n");
41 }
42 if ( *maze == 2 )//2表示墙壁,墙壁用X表示
43 {
44 printf ("X");
45 }
46 else if ( *maze == 1 )//1表示走过的路径,用“.”表示
47 {
48 printf (".");
49 }
50 else if ( *maze == 3 )//终点位置打印笑脸
51 {
52 putchar(1);
53 }
54 else//0表示可走路径,用“o”来表示
55 {
56 printf ("o");
57 }
58 maze++;
59 }
60 printf ("\n\n");
61 }
62
63 bool visit(int i, int j)
64 {
65 g_maze[i][j] = 1;
66 if ( (i==END_I) && (j==END_J) )
67 {
68 g_maze[i][j] = 3;
69 g_sucess = true;
70 return g_sucess;
71 }
72 else
73 {
74 //向下走
75 if ( (!g_sucess) && (g_maze[i][j+1]==0) )
76 {
77 visit(i, j+1);
78 }
79 //向右走
80 if ( (!g_sucess) && (g_maze[i+1][j]==0) )
81 {
82 visit(i+1, j);
83 }
84 //向上走
85 if ( (!g_sucess) && (g_maze[i][j-1]==0) )
86 {
87 visit(i, j-1);
88 }
89 //向左走
90 if ( (!g_sucess) && (g_maze[i-1][j]==0) )
91 {
92 visit(i-1, j);
93 }
94 if (!g_sucess)//如果还没有找到出口则说明该路线是死路,恢复该点原状
95 {
96 g_maze[i][j] = 0;
97 }
98 return g_sucess;
99 }
100 }
101
102
103
104 int main()
105 {
106
107 printf ("\t显示迷宫:\n\n");
108 printMaze(&(g_maze[0][0]), 9, 9);
109 if ( visit(1,1) )//把起点位置传进去
110 {
111 printf ("已找到出口,打印路径:\n\n");
112 printMaze(&(g_maze[0][0]), 9, 9);
113 }
114 else
115 {
116 printf ("没有找到出口!");
117 }
118 return 1;
119 }

Java版:

 1 public class MouseMaze {
2 int[][] g_maze = {
3 {2, 2, 2, 2, 2, 2, 2, 2, 2},
4 {2, 0, 0, 2, 0, 2, 0, 0, 2},//起点位置(1,1)
5 {2, 0, 2, 0, 0, 0, 0, 2, 2},
6 {2, 0, 0, 0, 2, 2, 0, 0, 2},
7 {2, 2, 2, 0, 0, 0, 2, 0, 2},
8 {2, 0, 0, 0, 2, 0, 2, 0, 2},
9 {2, 2, 2, 2, 0, 2, 0, 0, 2},
10 {2, 0, 0, 0, 0, 0, 0, 2, 2},//终点位置(7, 1)
11 {2, 2, 2, 2, 2, 2, 2, 2, 2},
12 };
13 boolean g_sucess = false;
14 int END_i = 7;
15 int END_j = 1;
16
17 public MouseMaze(){
18 }
19
20 public void printMaze(){
21 for(int i = 0; i < g_maze.length; i++){
22 for(int j = 0; j < g_maze[i].length; j++){
23 if(g_maze[i][j] == 2){
24 System.out.print('X');
25 }
26 else if (g_maze[i][j] == 0) {
27 System.out.print('o');
28 }
29 else if(g_maze[i][j] == 1)//走过的路径标记为1
30 System.out.print('.');
31 if(j == g_maze[i].length - 1){
32 System.out.print('\n');
33 }
34 }
35 }
36 }
37 //
38 public void visit(int i, int j){
39 //将走过的路径标为 1
40 g_maze[i][j] = 1;
41 //向上访问
42 if(i == END_i && j == END_j){
43 g_sucess = true;
44 return;
45 }
46 if(g_maze[i-1][j] == 0 && !g_sucess ){
47 visit(i - 1, j);
48 }
49 if(g_maze[i+1][j] == 0 && !g_sucess){
50 visit(i+1, j);
51 }
52 if(g_maze[i][j-1] == 0 && !g_sucess){
53 visit(i, j-1);
54 }
55 if(g_maze[i][j+1] == 0 && !g_sucess){
56 visit(i, j+1);
57 }
58 if(!g_sucess){
59 g_maze[i][j] = 0;
60 }
61 }
62 public static void main(String[] args) {
63 MouseMaze mm = new MouseMaze();
64 mm.printMaze();
65 mm.visit(1, 1);
66 System.out.println("-----------------");
67 mm.printMaze();
68 }
69 }

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

  1. 老鼠走迷宫II

    转自:http://blog.csdn.net/holymaple/article/details/8636234 由于迷宫的设计,老鼠走迷宫的入口至出口路径可能不止一条,如何求出所有的路径呢? 解法 ...

  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. C语言动态走迷宫

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

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

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

  9. 洛谷P1238 走迷宫

    洛谷1238 走迷宫 题目描述 有一个m*n格的迷宫(表示有m行.n列),其中有可走的也有不可走的,如果用1表示可以走,0表示不可以走,文件读入这m*n个数据和起始点.结束点(起始点和结束点都是用两个 ...

随机推荐

  1. Scala学习——隐式转换

    scala隐式转换 一.需求:为一个类添加一个新的方法 java:动态代理 scala:隐式转换 隐式转换例子: 1.man to superMan package top.ruandb.scala. ...

  2. 前端之html基础演示

    1.本地服务:下载淘宝镜像node.js :https://npm.taobao.org/mirrors/npm :本次下载的版本是 v10.0.0 2.下载成功后,到cmd窗口输入 node -v, ...

  3. 如何掌握C#的核心技术

    如何掌握C#的核心技术 感谢网友毛大神制作的图. 引子 前不久看到一个段子,某年宁波交警引进人脸识别技术抓拍行人闯红灯,结果一天下来被发现闯红灯次数最多的是珠海女子董小姐,日闯红灯3000多次.宁波交 ...

  4. 面试问题记录 二 (数据库、Linux、Redis)

    面试问题记录 二 (数据库.Linux.Redis) 前言 接着上次的面试问题记录,在最后还有几道问的数据结构方面的知识点要补充 还是那句话:如果文中解释有明显错误,劳烦请及时指正我,在这不胜感激!! ...

  5. xmind2020 zen 10.3.1安装破解教程

    hi大家好,xmind zen 2020 10.3.1是一款优秀的思维导图工具,我和我爸爸都在用,功能包括去掉xmind zen水印.上传图片等功能,支持windows操作系统! 文章教大家安装并解锁 ...

  6. Spring Cloud分区发布实践(4) FeignClient

    上面看到直接通过网关访问微服务是可以实现按区域调用的, 那么微服务之间调用是否也能按区域划分哪? 下面我们使用FeignClient来调用微服务, 就可以配合LoadBalancer实现按区域调用. ...

  7. 网络安全日记 ① IIS 之web服务器搭建以及dns转发配置

    IIS(internet info server)服务器的搭建 创建iis服务 打开光驱 选择网络应用服务 安装iis和ftp(后面有讲) 配置服务 通过管理工具打开iis 2. 此时80端口就已经开 ...

  8. ArrayList 源码底层实现解析 基于1.8

    ArrayList 介绍 ArrayList是一种线性数据结构,它的底层是用数组实现的,是动态数组.与Java中的数组相比,它的容量能动态增长.源代码里有解释.当创建一个数组的时候,就必须确定它的大小 ...

  9. 迈入 8K 时代,AI 驱动超高清 “视” 界到来

    2021 年,超高清迈入 "8K" 时代.超高清视频将带来全新视听体验,但超高清生产在内容生产层面也面临着超高清存量少.生产设备更新换代慢.制作周期成倍增加的困境.在 7 月 10 ...

  10. Bugku-web-字符?正则?

    题目意思很明显,根据给出的规则构造出合理的正则表达式然后通过get方式提交弹出Flag. i:字体大小 /..../表示开始和结束. .号表示匹配0-9任一数字 *号表示重复前一个字符多次 {4,7} ...