zoukankan      html  css  js  c++  java
  • 走迷宫(用队列bfs并输出走的路径)

    #include <iostream>
    #include <stack>
    #include <string.h>
    #include <stdio.h>
    #include<queue>
    #include<algorithm>
    using namespace std;
    int a[11][11]=
    {
        {1,1,1,1,1,1,1,1,1,1},{1,0,0,1,0,0,0,1,0,1},
        {1,0,0,1,0,0,0,1,0,1},{1,0,0,0,0,1,1,0,0,1},
        {1,0,1,1,1,0,0,0,0,1},{1,0,0,0,1,0,0,0,0,1},
        {1,0,1,0,0,0,1,0,0,1},{1,0,1,1,1,0,1,1,0,1},
        {1,1,0,0,0,0,0,0,0,1},{1,1,1,1,1,1,1,1,1,1}
    };
    int dir[4][2]={{-1,0},{0,1},{1,0},{0,-1}};
    int vis[11][11];//用来标记有没有走过(有没有在队列中)
    int b[11][11];//用来记录bfs的过程
    struct Node
    {
        int x,y;
    };
    queue<Node>q;
    int main()
    {
        memset(b,0,sizeof(b));
        memset(vis,0,sizeof(vis));
        while(!q.empty()) q.pop();//初始化队列
    
        Node start;
        start.x=1;
        start.y=1;
        vis[1][1]=1;
        b[1][1]=1;
        q.push(start);//把起点放进队列
        bool f=0;
        while(!q.empty())
        {
            Node temp;
            temp=q.front();//取出队头元素
            q.pop();
            int x=temp.x;
            int y=temp.y;
            if(x==8&&y==8)//若走到了
            {
                f=1;
                Node road[111];//用来记录路径
                //for(int i=1;i<=8;i++)//可以通过输出b数组来观察bfs的实现过程
                //{
                //    for(int j=1;j<=8;j++)
                //    {
                //        printf("%5d",b[i][j]);
                //    }
                //    cout<<endl;
                //}
                //cout<<b[8][8]<<endl;
                int k=1;
                while(!(x==1&&y==1))//通过b数组来找到之前是哪一个点走到x,y的
                {
                    road[k].x=x;
                    road[k++].y=y;
                    for(int i=0;i<4;i++)
                    {
                        int xx=x+dir[i][0];
                        int yy=y+dir[i][1];
                        if(xx<1||yy<1||xx>8||yy>8) continue;//超出范围的不要
                        if(b[xx][yy]==b[x][y]-1)
                        {
                            x=xx;//倒退回去
                            y=yy;
                            break;//一定要跳出,要把更新的x,y放到road里
                        }
                    }
                }
                road[k].x=1;//别忘了把起点放进去
                road[k].y=1;
                for(int i=k;i>=1;i--)//输出路径
                {
                    cout<<road[i].x<<" "<<road[i].y<<endl;
                }
            }
            if(f==1) //找到路了就不用再跑大循环了
                break;
    
            for(int i=0;i<4;i++)//遍历四个方向
            {
                int xx=x+dir[i][0];
                int yy=y+dir[i][1];
                if(a[xx][yy]==0&&vis[xx][yy]==0)
                {
                    vis[xx][yy]=1;
                    Node New;
                    New.x=xx;
                    New.y=yy;
                    b[xx][yy]=b[x][y]+1;//用来标记走到(xx,yy)是第几步
                    q.push(New);//放进队列
                }
            }
        }
        return 0;
    }
  • 相关阅读:
    奥赛-欧几里得算法-最大公约数
    dbForge Studio for MySQL 中文乱码问题
    【C++】纯C++实现http打开网页下载内容的功能
    【C++】C++string类总结
    【C++】C++中的string类的用法总结
    【网络编程/C++】修改本机ip地址
    MFC控件的SubclassDlgItem
    MFC 不让程序显示在任务栏上
    MFC中无边框窗口的拖动
    MFC 获取图像的大小
  • 原文地址:https://www.cnblogs.com/caiyishuai/p/13270922.html
Copyright © 2011-2022 走看看