迷宫求解非递归 DFS BFS(应用栈和队列)

栈和队列的应用对迷宫问题求解 没有递归 自己手动建的栈和队 并且输出路径 DFS的路径就是

栈中的坐标 BFS的路径在队又开了一个域存上一层的base值 语言还是用的C++ 感觉比C的封装性好很多

充分体会了一下DFS一边比BFS快 但是BFS是最优解而DFS可能不是最优解

 

#include <iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define Maze_size 100 //定义迷宫最大值
class Maze
{
public:
    char Maze_map[Maze_size][Maze_size];
    bool Maze_map_bj[Maze_size][Maze_size];
    int stack[Maze_size][2],top;//栈 栈顶指针
    int queue[Maze_size][3],base,qtop;//队列 0 1存坐标 2记录路径 对首指针 队尾指针
    int length,wide;//迷宫长,宽(竖,横)
    int startx,starty;//起点坐标
    int step[4][2];
    Maze();//初始化迷宫
    void input();//从键盘输入
    bool DFS();//利用栈深度优先遍历
    bool BFS();//利用队列广度优先遍历
    void outputDFSmap();//输出深度优先遍历路径
    void outputBFSmap();//输出广度优先遍历路径
};

Maze::Maze()//初始化
{
    length=wide=0;
    startx=starty=0;
    step= {{0,1},{0,-1},{1,0},{-1,0}};
    top=0;
}

void Maze::input()//输入
{
    do
    {
        cout<<"input length and wide of maze(length>0,wide>0)"<<endl;
        cin>>length>>wide;
    }
    while(length<=0||wide<=0);
    cout<<"input maze"<<endl;
    for(int i=0; i<length; i++)
        for(int j=0; j<wide; j++)
        {
            cin>>Maze_map[i][j];
            if(Maze_map[i][j]=='S')
                startx=i,starty=j;
        }
    cout<<"input end"<<endl;
}

bool Maze::DFS()
{
    top=0;
    memset(Maze_map_bj,0,sizeof(Maze_map_bj));
    stack[++top][0]=startx,stack[top][1]=starty;
    Maze_map_bj[startx][starty]=1;
    while(top!=0)
    {
        int x=stack[top][0],y=stack[top][1];
        for(int i=0; i<4; i++)
            if(Maze_map[x+step[i][0]][y+step[i][1]]=='E')
                return 1;
        bool flag=0;
        for(int i=0; i<4; i++)
            if(Maze_map[x+step[i][0]][y+step[i][1]]=='.'&&!Maze_map_bj[x+step[i][0]][y+step[i][1]])
            {
                stack[++top][0]=x+step[i][0],stack[top][1]=y+step[i][1];
                Maze_map_bj[x+step[i][0]][y+step[i][1]]=1;
                flag=1;
                break;
            }
        if(flag)
            continue;
        top--;
    }
    return 0;
}

void Maze::outputDFSmap()
{
    if(!DFS())
    {
        cout<<"maze bu neng zou = = "<<endl;
        return ;
    }
    char newmap[Maze_size][Maze_size];
    for(int i=0; i<length; i++)
        for(int j=0; j<wide; j++)
            newmap[i][j]=Maze_map[i][j];
    for(int i=2; i<=top; i++)
        newmap[stack[i][0]][stack[i][1]]='*';
    cout<<"DFS:"<<endl;
    for(int i=0; i<length; i++)
        for(int j=0; j<wide; j++)
        {
            cout<<newmap[i][j];
            if(j==wide-1)
                cout<<endl;
        }
    cout<<endl;
}

bool Maze::BFS()
{
    base=0,qtop=1;
    memset(Maze_map_bj,0,sizeof(Maze_map_bj));
    queue[base][0]=startx,queue[base][1]=starty,queue[base][2]=0;
    Maze_map_bj[startx][starty]=1;
    while(base!=qtop)
    {
        int x=queue[base][0],y=queue[base][1];
        for(int i=0; i<4; i++)
        {
            if(Maze_map[x+step[i][0]][y+step[i][1]]=='E')
                return 1;
            if(Maze_map[x+step[i][0]][y+step[i][1]]=='.'&&!Maze_map_bj[x+step[i][0]][y+step[i][1]])
            {
                queue[qtop][0]=x+step[i][0],queue[qtop][1]=y+step[i][1];
                queue[qtop][2]=base;
                qtop++;
                Maze_map_bj[x+step[i][0]][y+step[i][1]]=1;
            }
        }
        base++;
    }
    return 0;
}

void Maze::outputBFSmap()
{
    if(!BFS())
    {
        cout<<"maze bu neng zou = = "<<endl;
        return ;
    }
    char newmap[Maze_size][Maze_size];
    for(int i=0; i<length; i++)
        for(int j=0; j<wide; j++)
            newmap[i][j]=Maze_map[i][j];
    while(base!=0)
    {
        newmap[queue[base][0]][queue[base][1]]='*';
        base=queue[base][2];
    }
    cout<<"BFS:"<<endl;
    for(int i=0; i<length; i++)
        for(int j=0; j<wide; j++)
        {
            cout<<newmap[i][j];
            if(j==wide-1)
                cout<<endl;
        }
    cout<<endl;
}
int main()
{
    Maze a;
    a.input();
    a.outputBFSmap();
    a.outputDFSmap();
    return 0;
}

 

时间: 2024-10-09 17:36:37

迷宫求解非递归 DFS BFS(应用栈和队列)的相关文章

二叉树的存储方式以及递归和非递归的三种遍历方式

树的定义和基本术语 树(Tree)是n(n>=0)个结点的有限集T,T为空时称为空树,否则它满足如下两个条件:   (1)有且仅有一个特定的称为根(Root)的结点:   (2)其余的结点可分为m(m>=0)个互不相交的子集T1,T2,T3-Tm,其中每个子集又是一棵树,并称其为子树(Subtree). 树形结构应用实例: 1.日常生活:家族谱.行政组织结构:书的目录 2.计算机:资源管理器的文件夹:     编译程序:用树表示源程序的语法结构:     数据库系统:用树组织信息:     分

php实现无限级分类查询(递归、非递归)_php技巧

做PHP这么长时间,发现后台管理系统不可少的一个应用模块就是对栏目的分类,一般情况下栏目都要做成是无限级的,也就是说每个栏目理论上都可以添加子栏目.在我看来这种情况处理起来整体上说也不是很复杂,唯一一个相对来说较难的点是无限级栏目的查询. 下面就这种情况我来向大家做一个简单的介绍,对于这种无限级栏目的查询一般情况下有两种方式,其中一种就是使用栈的机制,另一种是使用递归函数的方式(当然递归函数实现机制也是借助于栈来实现的).就这两种方式下面我们分别介绍. 递归函数实现方式 上面提到,递归函数的也是

二叉搜索树与树的遍历非递归练习

复习了二叉搜索树的实现,包括插入.查找和删除操作,顺便做了下二叉树的三种遍历操作.全部操作采用非递归方式.   #include<iostream>   #include<stack>   using namespace std;     typedef int T;   // 值类型      // 节点定义    struct node {       T val;       node *left,*right;       node(const T& val):va

递归算法-C:用递归及非递归解决迷宫问题

问题描述 C:用递归及非递归解决迷宫问题 以下是现有的代码,但是递归放在里面出现错误,求大神给我改改. #include #include #define N 39 #define M 39 int X; int maze[N+2][M+2]; /******递归函数定义*******/ typedef struct { int x,y; }Dj; Dj move[4]; /******非递归函数定义*******/ struct point{ int row,col,predecessor;

c++ c 树-不用栈的非递归二叉树遍历 求改正 (C++新手)

问题描述 不用栈的非递归二叉树遍历 求改正 (C++新手) 原程序如下,添加了双亲域parent和标志域mark:不知道哪里不对: #include""iostream""using namespace std;class BinTree; class BinNode{private: int data; BinNode *lchild;BinNode *rchild;BinNode *parent;int mark;friend class BinTree; };

iostream-求大神将下列递归阶乘用标号以及goto语句用栈的形式转换为非递归语句

问题描述 求大神将下列递归阶乘用标号以及goto语句用栈的形式转换为非递归语句 #include #include #include #include #include using namespace std; stackS; int fact(int n){ S.push(L2,) L0: if(n==0) return 1; L1: return n*fact(n-1); L2: ; }

非递归先序-C++先序遍历非递归算法,可以进栈,不能出栈

问题描述 C++先序遍历非递归算法,可以进栈,不能出栈 #include #include #include"BinaryTree.h" using namespace std; const int stackIncreament = 20; //栈溢出时扩展空间增量 template class SeqStack{ public: int top; SeqStack(int sz=50); //建立一个空栈 ~SeqStack(){delete[] elements;} void p

采用栈数据结构的二叉树非递归遍历

[前言]树的遍历,根据访问自身和其子节点之间的顺序关系,分为前序,后序遍历.对于二叉树,每个节点至多有两个子节点(特别的称为左,右子节点),又有中序遍历.由于树自身具有的递归性,这些遍历函数使用递归函数很容易实现,代码也非常简洁.借助于数据结构中的栈,可以把树遍历的递归函数改写为非递归函数.   在这里我思考的问题是,很显然,循环可以改写为递归函数.递归函数是否借助栈这种数据结构改写为循环呢.因为函数调用中,call procedure stack 中存储了流程的 context,调用和返回相当

[LeetCode] Binary Tree Level Order Traversal 二叉树层次遍历(DFS | BFS)

目录:1.Binary Tree Level Order Traversal - 二叉树层次遍历 BFS 2.Binary Tree Level Order Traversal II - 二叉树层次遍历从低往高输出 BFS 3.Maximum Depth of Binary Tree - 求二叉树的深度 DFS4.Balanced Binary Tree - 判断平衡二叉树 DFS5.Path Sum - 二叉树路径求和判断DFS 题目概述:Given a binary tree, return