zoukankan      html  css  js  c++  java
  • 经典算法-(六)老鼠走迷宫

    问题描述:

    给定一个二维数组,数组中2表示墙壁,0表示通路,由此数组可展示为一个迷宫图。给定入口位置和出口位置,判断之间是否存在通路并显示出走出迷宫的道路。

    问题解答:

    实际上是使用回溯算法求解该问题,就是在上下左右四个方向试探,倘若有路则走一步,在新的位置继续在四个位置试探,并且对走过的路进行标记,倘若走到死胡同里,则退回上一步再来试探,以此类推,类似于图的深度优先算法,使用递归来实现。

    java实现:

    package a;
    import java.math.BigInteger;
    import java.util.*;
    public class Main{     
        public static  void main(String[] args)  {  
            System.out.println("请输入一数来开始");
            Scanner cin = new Scanner(System.in);       
            while(cin.hasNext()){
              String n=cin.next();
              int[][] maze =new int [][] {
                    {2,2,2,2,2,2,2,2,2},  
                    {2,0,0,0,0,0,0,0,2},  
                    {2,0,2,2,0,2,2,0,2},  
                    {2,0,2,0,0,2,0,0,2},  
                    {2,0,2,0,2,0,2,0,2},  
                    {2,0,0,0,0,0,2,0,2},  
                    {2,2,0,2,2,0,2,2,2},  
                    {2,0,0,0,0,0,0,0,2},  
                    {2,2,2,2,2,2,2,2,2}  
                    };   
                 xun(maze,1,1);
                    
     }
            cin.close();      
        }
        static void xun(int[][] a,int i,int j) {
                   a[i][j]=1; 
                if(i==7&&j==7)
                { System.out.println("打印一波:--------------");
                System.out.println();
                    for(int m=0;m<9;m++) {
                        for (int n=0;n<9;n++) {
                            System.out.print(a[m][n]+" ");
                        }
                        System.out.println();
                    }
                }
                if(a[i][j+1]==0) {
                      xun(a,i,j+1);
                    }
                if(a[i+1][j]==0) {
                        xun(a,i+1,j);    
                }
                 if(a[i-1][j]==0) {
                    xun(a,i-1,j);    
                }
                 if(a[i][j-1]==0) {
                    xun(a,i,j-1);    
                }
                 a[i][j]=0;
        }
    }

    运算结果:

    点评:

    现在的代码是将所有可能的路线都打印出来了,稍微修改下可以实现打印一种结果,打印了所有的结果正是体现了回溯法可实现遍历出所有可能的答案。

    顺便附上打印一种结果的实现代码 :

    c++实现:

    #include <stdio.h>
    #include <stdlib.h>
    
    int visit(int , int );
    
    int maze[7][7] = {
        {2, 2, 2, 2, 2, 2, 2},
        {2, 0, 0, 0, 0, 0, 2},
        {2, 0, 2, 0, 2, 0, 2},
        {2, 0, 0, 2, 0, 2, 2},
        {2, 2, 0, 2, 0, 2, 2},
        {2, 0, 0, 0, 0, 0, 2},
        {2, 2, 2, 2, 2, 2, 2} 
    };
    
    int startI = 1, startJ = 1;
    int endI = 5, endJ = 5;
    int success = 0;
    
    int main(void)
    {
        int i, j;
    
        printf("显示迷宫:
    ");
        for(i = 0; i < 7; i++)
        {
            for(j = 0; j < 7; j++)
            {
                if(maze[i][j] == 2)
                    printf("#");
                else
                    printf(" ");
            }
            printf("
    ");
        }
        
        if(visit(startI, startJ) == 0)
            printf("
    没有找到出口!
    ");
        else
        {
            printf("
    显示路径:
    ");
            for(i = 0; i < 7; i++)
            {
                for(j = 0; j < 7; j++)
                {
                    if(maze[i][j] == 2)
                        printf("#");
                    else if(maze[i][j] == 1)
                        printf("1");
                    else
                        printf(" ");
                }
                printf("
    ");        
            }
        }
        return 0;
    } 
    
    int visit(int i, int j)
    {
        maze[i][j] = 1;
        
        if(i == endI && j == endJ)
            success = 1;
            
        if(success != 1 && maze[i][j+1] == 0)
            visit(i, j+1); 
        if(success != 1 && maze[i+1][j] == 0)
            visit(i+1, j);
        if(success != 1 && maze[i][j-1] == 0)
            visit(i, j-1);
        if(success != 1 && maze[i-1][j] == 0)
            visit(i-1, j);
            
        if(success != 1)
            maze[i][j] = 0; 
        return success;
    }
  • 相关阅读:
    解决运行vue项目的报错This relative module was not found:
    Iterator 迭代器
    Strategy 策略模式
    Observer 观察者
    工厂模式总结(简单工厂,工厂方法,抽象工厂)
    Abstract Factory 抽象工厂
    Factroy 简单工厂
    Singleton 多线程
    Singleton 单例模式
    设计模式总结
  • 原文地址:https://www.cnblogs.com/wwwhza/p/7694987.html
Copyright © 2011-2022 走看看