bfs加队列求迷宫最短路

例题:gdufe acm 1393



二进制迷宫
Time Limit: 2000/1000ms (Java/Others)
Problem Description:

     大白,上课的时候不小心进了一个八行八列二进制迷宫,数字0是路数字1是障碍,他希望你编写一个程序可以让他以最小步数走出迷宫,好让他可以快点重回现实世界,大白不仅可以上下左右走,更可以斜着走,斜着走或上下左右走都只算一步。坐标(00)为迷宫的入口,坐标(77)为出口

Input:

输入包括多组数据。
每组数据:输入n,表示有n个例子,输入八行八列的01的二进制迷宫。


Output:

如果大白能走出迷宫则输出最小步数,如果走不出迷宫则输出-1

Sample Input:

1

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

Sample Output:

7


#include <bits/stdc++.h>
using namespace std;
int n;
const int N = 8;
int mapp[N][N];
int vis[N][N];
int dd[][2] = {{-1, -1}, {-1, 0}, {-1, 1}, {0, -1}, {0, 1}, {1, -1}, {1, 0}, {1, 1}};
struct node{
    int x, y, s;
    node(){}
    node(int a, int b, int c):x(a), y(b), s(c){}
};
bool check(int x, int y){
    if(x < 0 || x > 7 || y < 0 || y > 7 || vis[x][y] || mapp[x][y])
        return false;
    return true;
}
int bfs(int x, int y){
    queue <node> q;
    memset(vis, 0, sizeof(vis));
    node t = node(0, 0, 0);
    q.push(t);
    vis[0][0] = 1;
    while(!q.empty()){
        t = q.front();
        q.pop();
        if(t.x == 7 && t.y == 7)
            return t.s;
        for(int i = 0; i < 8; i++){
            int xx = t.x + dd[i][0], yy = t.y + dd[i][1];
            if(check(xx, yy)){
                vis[xx][yy] = 1;
                node tmp = node(xx, yy, t.s + 1);
                q.push(tmp);
            }
        }
    }
    return -1;
}
int main(){
     while(scanf("%d", &n) == 1){
        while(n--){
            for(int i = 0; i < 8; i++)
                for(int j = 0; j < 8; j++)
                    scanf("%d", &mapp[i][j]);
            int ans = bfs(0, 0);
            printf("%d\n", ans);
        }
     }
     return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值