zoukankan      html  css  js  c++  java
  • 深度搜索--poj3984 迷宫问题

    题目:

    定义一个二维数组: 
    
    int maze[5][5] = {
    
        0, 1, 0, 0, 0,
    
        0, 1, 0, 1, 0,
    
        0, 0, 0, 0, 0,
    
        0, 1, 1, 1, 0,
    
        0, 0, 0, 1, 0,
    
    };
    
    它表示一个迷宫,其中的1表示墙壁,0表示可以走的路,只能横着走或竖着走,不能斜着走,要求编程序找出从左上角到右下角的最短路线。

    input:

    一个5 × 5的二维数组,表示一个迷宫。数据保证有唯一解。

    output:

    左上角到右下角的最短路径,格式如样例所示。

    sample input:

    0 1 0 0 0
    0 1 0 1 0
    0 0 0 0 0
    0 1 1 1 0
    0 0 0 1 0

    sample output:

    (0, 0)
    (1, 0)
    (2, 0)
    (2, 1)
    (2, 2)
    (2, 3)
    (2, 4)
    (3, 4)
    (4, 4)

    AC code:

    #include<stack>
    #include<iostream>
    #include<cstdio>
    using namespace std;
    
    stack<int> s1,s2;
    int maze[5][5];
    
    bool dfs(int x,int y)
    {
        if(x==4&&y==4)         //dfs递归的出口
        {
            s1.push(x);             //记录迷宫出口的坐标,返回true给上一层的if判断;
            s2.push(y);
            return true;
        }
        if(x>=0&&x<=4&&y>=0&&y<=4)
        {
            if(maze[x][y]==0)
            {
                maze[x][y]=1;
                if(dfs(x,y+1)||dfs(x+1,y)||dfs(x-1,y)||dfs(x,y-1))   //这个判断条件对唯一解才能有效的判断,若解不唯一,应当重新设定dfs函数的循环跳出条件;
                {
                    s1.push(x);     //若最后的结果可行,从出口往入口进栈,然后不断的返回true给上一层if调用,不断的进栈记录路径;
                    s2.push(y);
                    return true; 
                }
                else
                {
                    maze[x][y]=0;        //如果走不通,则返回false,这样就不断的重新恢复迷宫原来的都1与0;
                    return false;
                }
            }
            else
            {
                return false;
            }
        }
        else
        {
            return false;
        }
    }
    
    void print()
    {
        while(s1.empty()!=true)
        {
            printf("(%d, %d)
    ",s1.top(),s2.top());
            s1.pop();
            s2.pop();
        }
    }
    
    int main()
    {
        int temp=0;
        while(scanf("%d",&temp)!=EOF)
        {
            for(int i=0;i<5;i++)
            {
                for(int j=0;j<5;j++)
                {
                    if(i==0&&j==0)  {maze[i][j]=temp;continue;}
                    else scanf("%d",&maze[i][j]);
                }
            }
            dfs(0,0);
            print();
        }
        return 0;
    }

    TIP:

    解题思路:深度优先搜索+递归
    难度:入门级经典

  • 相关阅读:
    NYOJ 23 取石子(一)
    XYNUOJ 2026 素数环
    XYNUOJ 1756 魔法工会
    XYNUOJ 1784 胜利大逃亡
    NYOJ 18 The Triangle
    NYOJ 737 合并石子
    XYNUOJ 问题 B: 敌兵布阵
    NYOJ 1063 生活的烦恼
    XYNUOJ 1774 最少拦截系统
    XYNUOJ 1248 排队打水问题
  • 原文地址:https://www.cnblogs.com/myxdashuaige/p/8654055.html
Copyright © 2011-2022 走看看