• 【BFS】【AOJ-6】Hero In Maze


    Description
    500年前,Jesse是我国最卓越的剑客。他英俊潇洒,而且机智过人^_^。

    突然有一天,Jesse心爱的公主被魔王困在了一个巨大的迷宫中。Jesse听说这个消息已经是两天以后了,他知道公主在迷宫中还能坚持T天,他急忙赶到迷宫,开始到处寻找公主的下落。
    时间一点一点的过去,Jesse还是无法找到公主。最后当他找到公主的时候,美丽的公主已经死了。从此Jesse郁郁寡欢,茶饭不思,一年后追随公主而去了。T_T
    500年后的今天,Jesse托梦给你,希望你帮他判断一下当年他是否有机会在给定的时间内找到公主。

    他会为你提供迷宫的地图以及所剩的时间T。请你判断他是否能救出心爱的公主。
    Input
    题目包括多组测试数据。
    每组测试数据以三个整数N,M,T(0 < N,M <= 20)开头,
    分别代表迷宫的长和高,以及公主能坚持的天数。
    紧接着有M行,N列字符,由".","*","P","S"组成。其中
    "." 代表能够行走的空地。
    "*" 代表墙壁,Jesse不能从此通过。
    "P" 是公主所在的位置。
    "S" 是Jesse的起始位置。
    每个时间段里Jesse只能选择“上、下、左、右”任意一方向走一步。
    输入以0 0 0结束。
    Output
    如果能在规定时间内救出公主输出“YES”,否则输出“NO”。
    Sample Input
    4 4 10
    ....
    ....
    ....
    S**P
    0 0 0

     
    Sample Output
    YES

     
    思路:
    没啥好说的 广度优先搜索  不明白的翻数据结构图那部分 
     
    参考代码;
    #include<stdio.h>   
    #include<string.h>   
    #define WALL -1   
    #define RODE 1000000   
    int nx[50000],ny[50000],movex[4]={1,-1,0,0},movey[4]={0,0,1,-1},map[100][100];   
    void bfs(int sx,int sy)   
    {   
        int front = 0,rear = 1;   
        nx[0] = sx;   
        ny[0] = sy;   
        map[sx][sy] = 0;   
        while(front < rear)   
        {   
            int i;   
            for(i = 0;i < 4;i++)   
            {   
                int newx = nx[front] + movex[i],newy = ny[front] + movey[i];   
                if(map[newx][newy] != WALL && map[nx[front]][ny[front]] + 1 < map[newx][newy])   
                {   
                    map[newx][newy] = map[nx[front]][ny[front]] + 1;   
                    nx[rear] = newx;   
                    ny[rear] = newy;   
                    rear++;   
                }   
            }   
            front++;   
        }   
    }   
          
    int main()   
    {   
        //freopen("data.in","r",stdin);   
        int px,py,sx,sy,n,m,t,i,j;  
        while(scanf("%d%d%d",&n,&m,&t) && n != 0)  
        {  
            getchar();  
            memset(map,WALL,sizeof(map));  
            for(i = 0;i < m;i++)  
            {  
                for(j = 0;j < n;j++)  
                {  
                    char temp;  
                    scanf("%c",&temp);  
                    if(temp == '*') map[i][j] = WALL;  
                    else map[i][j] = RODE;  
                    if(temp == 'S') sx = i,sy = j;  
                    if(temp == 'P') px = i,py = j;  
                }  
                getchar();  
            }  
            bfs(sx,sy);  
            int ans = map[px][py];  
            if(ans <= t) puts("YES");  
            else puts("NO");  
        }  
        return 0;  
    }
    
     
  • 相关阅读:
    Python网络编程(weekly summary1)
    Python网络编程(子进程的创建与处理、简单群聊工具)
    Python网络编程(epoll内核监听,多任务多进程)
    Python网络编程(http协议,IO多路复用、select内核监听)
    Python网络编程(socket模块、缓冲区、http协议)
    Python网络编程(OSI模型、网络协议、TCP)
    Linux(Ubuntu 命令大全)
    计算机中的进制和编码
    算法图解(选择排序)
    Python全栈 MySQL 数据库(SQL命令大全、MySQL 、Python调用)
  • 原文地址:https://www.cnblogs.com/ahu-shu/p/3521500.html
Copyright © 2020-2023  润新知