zoukankan      html  css  js  c++  java
  • zzulioj1908: 小火山的围棋梦想

    Description

      小火山最近喜欢上了围棋。
      对于围棋,其实小火山是一窍不通的。现在棋盘上,有很多小火山的棋子。 如果棋盘上有这样的一个位置, 那么这个位置也会变成小火山
    的棋子;这样的位置是指小火山的棋子将该位置围起来。
      现在,小火山想知道实际棋盘是什么样子的。 你快来帮帮他吧!

    Input

    输入第一行是一个整数T(T <= 30), 表示一共有T组数据。
    每组数据,第一行为两个整数n, m(1 <= n, m <= 25),  随后一个n*m的矩阵代表棋盘,其中"."是代表没放棋子的位置, "*"代表小火山的棋子。

    Output

    对于每组数据输出一个n*m的棋盘, 代表实际的棋盘。

    Sample Input

    2
    3 3
    ***
    *.*
    *** 
    4 4
    .*.. 
    *.*. 
    *.*. 
    .*..

    Sample Output

    Case 1:
    ***
    ***
    ***
    Case 2:
    .*..
    ***.
    ***.
    .*..
    看每个点能不能够跑到边缘 能就说明没有被围住  比较简单的dfs
    #include<cstdio>
    #include<cstring>
    #include<algorithm>
    using namespace std;
    char map[50][50];
    int vis[50][50];
    int n,m,flog;
    void dfs(int x,int y)
    {
    	if(map[x][y]=='.'&&(x==0||y==0||x==n-1||y==m-1))
    	{
    		flog=1;
    		return ;
    	}
    	else
    	{
    		if(x>=0&&y>=0&&x<n&&y<m&&vis[x][y]==0&&map[x][y]=='.')
    		{
    			vis[x][y]=1;
    			dfs(x+1,y);
    			dfs(x-1,y);
    			dfs(x,y+1);
    			dfs(x,y-1);
    		}
    		else
    		{
    			return ;
    		}
    	}
    }
    int main()
    {
    	 int t,cut=0;
    	 scanf("%d",&t);
    	 while(t--)
    	{
    		cut++;
    	
    		scanf("%d%d",&n,&m);
    		for(int i=0;i<n;i++)
    		{
    				scanf("%s",map[i]);
    		}
    		for(int i=0;i<n;i++)
    		{
    		
    			for(int j=0;j<m;j++)
    			{
    			
    				if(map[i][j]=='.')
    				{
    					memset(vis,0,sizeof(vis));
    					flog=0;
    					dfs(i,j);
    					if(flog==0)
    					{
    						map[i][j]='*';
    					}
    					}	
    			}
    		}
    		printf("Case %d:
    ",cut);
    		for(int i=0;i<n;i++)
    		{
    			for(int j=0;j<m;j++)
    			{
    				printf("%c",map[i][j]);
    			}
    			printf("
    ");
    		}
    	}
    	return 0;
    }




  • 相关阅读:
    response.redirect on asp.net is a 302 jump action
    什么吃掉了我的硬盘?
    百度流量统计将会影响搜索的排名
    发邮件 python
    bottle template usage
    想提神,喝中药,咖啡可可没用的
    企业退信的常见问题?
    用UnixBench测试VPS性能 判别是否值得购买
    域名注册及免费空间and企业邮箱
    LNMP一键安装包是什么?
  • 原文地址:https://www.cnblogs.com/kingjordan/p/12027071.html
Copyright © 2011-2022 走看看