結果
| 問題 | No.1588 Connection | 
| コンテスト | |
| ユーザー |  merlin | 
| 提出日時 | 2021-07-09 00:03:33 | 
| 言語 | Java (openjdk 23) | 
| 結果 | 
                                WA
                                 
                            (最新) 
                                QLE
                                 
                            (最初) | 
| 実行時間 | - | 
| コード長 | 3,012 bytes | 
| コンパイル時間 | 2,450 ms | 
| コンパイル使用メモリ | 87,956 KB | 
| 実行使用メモリ | 83,432 KB | 
| 平均クエリ数 | 425.47 | 
| 最終ジャッジ日時 | 2024-07-17 12:46:03 | 
| 合計ジャッジ時間 | 10,580 ms | 
| ジャッジサーバーID (参考情報) | judge3 / judge4 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 1 | 
| other | AC * 13 WA * 18 | 
ソースコード
import java.io.*;
import java.util.*;
class Main
{
    public static void main(String args[])throws Exception
    {
        BufferedReader bu=new BufferedReader(new InputStreamReader(System.in));
        StringBuilder sb=new StringBuilder();
        String s[]=bu.readLine().split(" ");
        int n=Integer.parseInt(s[0]),m=Integer.parseInt(s[1])-2;
        boolean b[][]=new boolean[n+1][n+1];
        b[1][1]=b[n][n]=true;
        ArrayList<Pair> g[]=new ArrayList[2*n+1];
        int i,j;
        for(i=0;i<=2*n;i++) g[i]=new ArrayList<>();
        for(i=1;i<=n;i++)
        for(j=1;j<=n;j++) g[i+j].add(new Pair(i,j));
        int l=2,r=2*n; boolean vis[][]=new boolean[n+1][n+1];
        while(l<=r)
        {
            Queue<Pair> q=new LinkedList<>();
            for(Pair x:g[l])
            {
                if(b[x.x][x.y] && x.x+1<=n && !vis[x.x+1][x.y])
                {
                    vis[x.x+1][x.y]=true;
                    q.add(new Pair(x.x+1,x.y));
                }
                if(b[x.x][x.y] && x.y+1<=n && !vis[x.x][x.y+1])
                {
                    vis[x.x][x.y+1]=true;
                    q.add(new Pair(x.x,x.y+1));
                }
            }
            for(Pair x:g[r])
            {
                if(b[x.x][x.y] && x.x-1>0 && !vis[x.x-1][x.y])
                {
                    vis[x.x-1][x.y]=true;
                    q.add(new Pair(x.x-1,x.y));
                }
                if(b[x.x][x.y] && x.y-1>0 && !vis[x.x][x.y-1])
                {
                    vis[x.x][x.y-1]=true;
                    q.add(new Pair(x.x,x.y-1));
                }
            }
            while(!q.isEmpty())
            {
                Pair p=q.poll();
                System.out.print(p.x+" "+p.y+"\n");
                System.out.flush();
                String ver=bu.readLine();
                if(ver.charAt(0)=='-') return;
                if(ver.charAt(0)=='B')
                {
                    m--;
                    b[p.x][p.y]=true;
                }
                if(m==0) break;
            }
            if(m==0) break;
            l++; r--;
        }
        for(i=1;i<=n;i++) Arrays.fill(vis[i],false);
        vis[1][1]=true; int di[][]={{-1,0},{0,1},{1,0},{0,-1}};
        Queue<Pair> q=new LinkedList<>();
        q.add(new Pair(1,1));
        while(!q.isEmpty())
        {
            Pair p=q.poll();
            for(int d[]:di)
            {
                int tx=p.x+d[0],ty=p.y+d[1];
                if(tx>0 && tx<=n && ty>0 && ty<=n && !vis[tx][ty] && b[tx][ty])
                {
                    q.add(new Pair(tx,ty));
                    vis[tx][ty]=true;
                }
            }
        }
        if(vis[n][n] || (l>=r && m>0)) sb.append("Yes\n");
        else sb.append("No\n");
        System.out.print(sb);
        System.out.flush();
        return;
    }
    static class Pair
    {
        int x,y;
        Pair(int a,int b)
        {
            x=a;
            y=b;
        }
    }
}
            
            
            
        