uva 784 - Maze Exploration

简介: 点击打开链接 题目意思:给定一个房间,房间四周都是封闭的,但是房间里面会有相通的门,开始里面有个点要求从这个点开始能够填到的地方全部标记为#,包括自己,输出填充后的房间地图 解题思路:简单的floodfill思路,利用dfs就可以做,从起...

点击打开链接


题目意思:给定一个房间,房间四周都是封闭的,但是房间里面会有相通的门,开始里面有个点要求从这个点开始能够填到的地方全部标记为#,包括自己,输出填充后的房间地图


解题思路:简单的floodfill思路,利用dfs就可以做,从起点开始递归搜索,注意输入的格式


代码:


#include <iostream>
#include <queue>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int MAXN = 100;
//结构体存储坐标
struct point{
    int x;
    int y;
};
point p;
        
int n , r , c;
char maze[MAXN][MAXN];//存储房间的数组
int dir[4][2] = {{-1,0},{0,1},{1,0},{0,-1}};

//处理函数
void Dfs(int i , int j){
    for(int k = 0 ; k < 4 ;k++){
        if(maze[i+dir[k][0]][j+dir[k][1]] == 'X')
            continue;
        if(maze[i+dir[k][0]][j+dir[k][1]] == ' '){
            maze[i][j] = '#';//填充
            Dfs(i+dir[k][0] , j+dir[k][1]);
        }
    }
    maze[i][j] = '#';
}

//输出函数
void output(){
    int i , j , len;
    for(i = 0 ; i <= r ; i++){
        len = strlen(maze[i]);
        for(j = 0 ; j < len ; j++)
            printf("%c" , maze[i][j]);
        cout<<endl;
    }
}

//主函数
int main(){
    int i , j , mark;
    i = 0 ; 
    cin>>n;
    getchar();
    for(int t = 1 ; t <= n ; t++){
        i = 0;mark = 0;//mark标记是否找到了起始点
        while(gets(maze[i])){//用gets输入一串字符串
            if(maze[i][0] == '_')
                break;
            else{
                if(mark == 0){
                    int len = strlen(maze[i]);
                    for(j = 0 ; j < len ; j++){
                        if(maze[i][j] == '*'){
                            p.x = i;//存储起始点的坐标
                            p.y = j;
                            mark = 1;
                        }
                    }
                }
                i++;
            }
        }
        r = i ;//记录行数
        Dfs(p.x , p.y);
        output();
    }
}





目录
相关文章
|
10月前
UVa11679 - Sub-prime
UVa11679 - Sub-prime
35 0
CodeForces 377A-Maze(DFS找连通块)
CodeForces 377A-Maze(DFS找连通块)
CodeForces 377A-Maze(DFS找连通块)
洛谷P1825-[USACO11OPEN]Corn Maze S(BFS)
洛谷P1825-[USACO11OPEN]Corn Maze S(BFS)
洛谷P1825-[USACO11OPEN]Corn Maze S(BFS)
|
人工智能 BI 算法
|
定位技术
codeforces 377A Maze
点击打开cf377A 题意:给定一个n*m的地图,这个地图初始化有s个空地,并且这s个空地是连通的。现在要求找到一种方案放k个的墙到这个地图使得剩下的s-k个点还是连通的 思路:因为初始化的地图是一个连通的,要求s-k个点也是连通的。
998 0
uva 1121 - Subsequence
点击打开链接uva 1121 思路:二分查找 分析: 1 题目要求找到一个最短的子序列长度并且这个子序列的和大于等于给定的s 2 如果按照常规的做法枚举起点和终点的话肯定是会超时的。
912 0
|
SQL
uva 10881 - Piotr's Ants
点击打开链接uva 10881 思路:模拟 分析: 1 如果把蚂蚁看成是没有区别的点,那么只需计算出每只蚂蚁在t秒之后的位置即可。比如有三只蚂蚁,蚂蚁1 = (1,L),蚂蚁2 = (3 , L) , 蚂蚁3 = (4,L),则两秒钟之后,3只蚂蚁的位置分别为(3 , R) , (1 , L) , (2 , L)。
801 0