CDOJ 1221 Ancient Go
admin
2023-07-30 07:20:10
0

CDOJ 1221 Ancient Go

#includeusing namespace std;bool ok;char maze[15][15];char Map[12][12];bool vis[15][15];int x[4] = {0,0,1,-1};int y[4] = {1,-1,0,0};struct ST
{    int ii;    int jj;
};
queue que;void BFS(int cur_i, int cur_j)
{    int dot = 0;    while(!que.empty())
        que.pop();
    ST now;
    now.ii = cur_i;
    now.jj = cur_j;
    que.push(now);    while(!que.empty())
    {
        now = que.front();
        que.pop();
        vis[now.ii][now.jj] = 1;        for(int i=0;i<4;i++)
        {            int tempX = now.ii + x[i];            int tempY = now.jj + y[i];
            ST Next;
            Next.ii = tempX;
            Next.jj = tempY;            if(tempX >=0 && tempX <= 10 && tempY >=0 && tempY <= 10 && !vis[tempX][tempY])
            {                if(Map[tempX][tempY]=='.')
                {
                    dot++;
                    vis[tempX][tempY] = 1;
                }                else if(Map[tempX][tempY]=='o')
                {
                    que.push(Next);
                    vis[tempX][tempY] = 1;
                }
            }
        }
    }    if(dot == 1)
    {
        ok = 1;
    }    return ;
}int main()
{    int t;
    cin>>t;    int kase = 1;    while(t--)
    {
        ok = 0;        for(int i=0;i<=8;i++)
            cin>>maze[i];        for(int i=0;i<=10;i++)
        {            for(int j=0;j<=10;j++)
            {                if(i==0||j==0||i==10||j==10)
                    Map[i][j] = 'x';                else
                    Map[i][j] = maze[i-1][j-1];
            }
        }

        memset(vis, 0, sizeof(vis));        for(int i=1;i<=9;i++)
        {            for(int j=1;j<=9;j++)
            {                if(Map[i][j]=='o'&&!vis[i][j])
                    BFS(i, j);                for(int ii=1;ii<=9;ii++)                    for(int jj=1;jj<=9;jj++)                        if(Map[ii][jj] == '.')
                            vis[ii][jj] = 0;                if(ok)                    goto here;
            }
        }
        here:;        if(ok)
            printf("Case #%d: Can kill in one move!!!\n", kase++);        else
            printf("Case #%d: Can not kill in one move!!!\n", kase++);       // cout<

CDOJ 1221 Ancient Go


相关内容

热门资讯

四川绵竹接连发生3次四级以上地... 中国地震台网正式测定:今日23时30分在四川德阳市绵竹市(北纬31.58度,东经104.00度)发生...
大神Karpathy用Clau... 编辑|泽南、杨文 上班真是有毒啊。 连 Andrej Karpathy(安德烈・卡帕西)这样的 AI...
我国成功发射千帆极轨13组卫星 7月4日 据央视新闻 北京时间7月4日17时30分,我国在太原卫星发射中心使用长征六号改运载火箭,成...
业内首个AI-eSIM产业协同... 来源:人民邮电报 7月3日,在中国信息通信业发展高层论坛上,由中国移动发起的业内首个AI-eSIM产...
原创 小... 这个“沦为”没有贬低的意思,完全只是事实,因为以现在存储的价格,现实中几乎所有的消费电子产品,都在成...
天韵相机完成出舱安装,中国空间... 近日,神舟二十三号乘组完成了天韵相机舱内组装测试和出舱安装任务。天韵相机能精准监测全球中低纬度重点区...
2026中国互联网大会7月8日... (来源:IT之家) IT之家 7 月 5 日消息,2026(第二十五届)中国互联网大会将于 7 月 ...
约为上一代机型同期销量的90%... 众所周知, @vivo 新一代大折叠手机X Fold6已于7月1日正式开售,那么该机首销的情况怎么样...
一等9小时!东京千人排长队抢购... 深圳商报·读创客户端记者 苑伟斌 近日,一款国产双摄云台相机在东京涩谷掀起“排队抢购潮”。 涩谷是...
美军:暂停搜寻在阿拉伯海失踪的... 当地时间5日,美国海军中央司令部在社交平台上发布消息称,美国海军已于当地时间5日15时暂停对一名失踪...