Submission #420588


Source Code Expand

import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.PrintWriter;
import java.util.Arrays;
import java.util.InputMismatchException;

public class Main {
	static InputStream is;
	static PrintWriter out;
	static String INPUT = "";
	
	static void solve()
	{
		int n = ni(), m = ni();
		char[][] map = nm(n,m);
		int sr = -1, sc = -1;
		int gr = -1, gc = -1;
		for(int i = 0;i < n;i++){
			for(int j = 0;j < m;j++){
				if(map[i][j] == 's'){
					sr = i; sc = j;
					map[i][j] = '.';
				}
				if(map[i][j] == 'g'){
					gr = i; gc = j;
					map[i][j] = '.';
				}
			}
		}
		
		DJSet ds = new DJSet(n*m);
		for(int i = 0;i < n;i++){
			for(int j = 0;j < m-1;j++){
				if(map[i][j] == map[i][j+1]){
					ds.union(i*m+j, i*m+j+1);
				}
			}
		}
		for(int i = 0;i < n-1;i++){
			for(int j = 0;j < m;j++){
				if(map[i][j] == map[i+1][j]){
					ds.union(i*m+j, (i+1)*m+j);
				}
			}
		}
		
		out.println(ds.equiv(sr*m+sc, gr*m+gc) ? "Yes" : "No");
	}
	
	public static class DJSet {
		public int[] upper;

		public DJSet(int n) {
			upper = new int[n];
			Arrays.fill(upper, -1);
		}

		public int root(int x) {
			return upper[x] < 0 ? x : (upper[x] = root(upper[x]));
		}

		public boolean equiv(int x, int y) {
			return root(x) == root(y);
		}

		public boolean union(int x, int y) {
			x = root(x);
			y = root(y);
			if (x != y) {
				if (upper[y] < upper[x]) {
					int d = x;
					x = y;
					y = d;
				}
				upper[x] += upper[y];
				upper[y] = x;
			}
			return x == y;
		}

		public int count() {
			int ct = 0;
			for (int u : upper)
				if (u < 0)
					ct++;
			return ct;
		}
	}
	
	public static void main(String[] args) throws Exception
	{
		long S = System.currentTimeMillis();
		is = INPUT.isEmpty() ? System.in : new ByteArrayInputStream(INPUT.getBytes());
		out = new PrintWriter(System.out);
		
		solve();
		out.flush();
		long G = System.currentTimeMillis();
		tr(G-S+"ms");
	}
	
	private static boolean eof()
	{
		if(lenbuf == -1)return true;
		int lptr = ptrbuf;
		while(lptr < lenbuf)if(!isSpaceChar(inbuf[lptr++]))return false;
		
		try {
			is.mark(1000);
			while(true){
				int b = is.read();
				if(b == -1){
					is.reset();
					return true;
				}else if(!isSpaceChar(b)){
					is.reset();
					return false;
				}
			}
		} catch (IOException e) {
			return true;
		}
	}
	
	private static byte[] inbuf = new byte[1024];
	static int lenbuf = 0, ptrbuf = 0;
	
	private static int readByte()
	{
		if(lenbuf == -1)throw new InputMismatchException();
		if(ptrbuf >= lenbuf){
			ptrbuf = 0;
			try { lenbuf = is.read(inbuf); } catch (IOException e) { throw new InputMismatchException(); }
			if(lenbuf <= 0)return -1;
		}
		return inbuf[ptrbuf++];
	}
	
	private static boolean isSpaceChar(int c) { return !(c >= 33 && c <= 126); }
//	private static boolean isSpaceChar(int c) { return !(c >= 32 && c <= 126); }
	private static int skip() { int b; while((b = readByte()) != -1 && isSpaceChar(b)); return b; }
	
	private static double nd() { return Double.parseDouble(ns()); }
	private static char nc() { return (char)skip(); }
	
	private static String ns()
	{
		int b = skip();
		StringBuilder sb = new StringBuilder();
		while(!(isSpaceChar(b))){
			sb.appendCodePoint(b);
			b = readByte();
		}
		return sb.toString();
	}
	
	private static char[] ns(int n)
	{
		char[] buf = new char[n];
		int b = skip(), p = 0;
		while(p < n && !(isSpaceChar(b))){
			buf[p++] = (char)b;
			b = readByte();
		}
		return n == p ? buf : Arrays.copyOf(buf, p);
	}
	
	private static char[][] nm(int n, int m)
	{
		char[][] map = new char[n][];
		for(int i = 0;i < n;i++)map[i] = ns(m);
		return map;
	}
	
	private static int[] na(int n)
	{
		int[] a = new int[n];
		for(int i = 0;i < n;i++)a[i] = ni();
		return a;
	}
	
	private static int ni()
	{
		int num = 0, b;
		boolean minus = false;
		while((b = readByte()) != -1 && !((b >= '0' && b <= '9') || b == '-'));
		if(b == '-'){
			minus = true;
			b = readByte();
		}
		
		while(true){
			if(b >= '0' && b <= '9'){
				num = num * 10 + (b - '0');
			}else{
				return minus ? -num : num;
			}
			b = readByte();
		}
	}
	
	private static long nl()
	{
		long num = 0;
		int b;
		boolean minus = false;
		while((b = readByte()) != -1 && !((b >= '0' && b <= '9') || b == '-'));
		if(b == '-'){
			minus = true;
			b = readByte();
		}
		
		while(true){
			if(b >= '0' && b <= '9'){
				num = num * 10 + (b - '0');
			}else{
				return minus ? -num : num;
			}
			b = readByte();
		}
	}
	
	private static void tr(Object... o) { if(INPUT.length() != 0)System.out.println(Arrays.deepToString(o)); }
}

Submission Info

Submission Time
Task A - 深さ優先探索
User uwi
Language Java (OpenJDK 1.7.0)
Score 100
Code Size 4829 Byte
Status AC
Exec Time 431 ms
Memory 26572 KB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 100 / 100
Status
AC × 5
AC × 83
Set Name Test Cases
Sample 00_sample_01.txt, 00_sample_02.txt, 00_sample_03.txt, 00_sample_04.txt, 00_sample_05.txt
All 00_min_01.txt, 00_min_02.txt, 00_min_03.txt, 00_min_04.txt, 00_min_05.txt, 00_min_06.txt, 00_min_07.txt, 00_min_08.txt, 00_sample_01.txt, 00_sample_02.txt, 00_sample_03.txt, 00_sample_04.txt, 00_sample_05.txt, 01_rnd_00.txt, 01_rnd_01.txt, 01_rnd_02.txt, 01_rnd_03.txt, 01_rnd_04.txt, 01_rnd_05.txt, 01_rnd_06.txt, 01_rnd_07.txt, 01_rnd_08.txt, 01_rnd_09.txt, 01_rnd_10.txt, 01_rnd_11.txt, 01_rnd_12.txt, 01_rnd_13.txt, 01_rnd_14.txt, 01_rnd_15.txt, 01_rnd_16.txt, 01_rnd_17.txt, 01_rnd_18.txt, 01_rnd_19.txt, 02_rndhard_00.txt, 02_rndhard_01.txt, 02_rndhard_02.txt, 02_rndhard_03.txt, 02_rndhard_04.txt, 02_rndhard_05.txt, 02_rndhard_06.txt, 02_rndhard_07.txt, 02_rndhard_08.txt, 02_rndhard_09.txt, 02_rndhard_10.txt, 02_rndhard_11.txt, 02_rndhard_12.txt, 02_rndhard_13.txt, 02_rndhard_14.txt, 02_rndhard_15.txt, 02_rndhard_16.txt, 02_rndhard_17.txt, 02_rndhard_18.txt, 02_rndhard_19.txt, 02_rndhard_20.txt, 02_rndhard_21.txt, 02_rndhard_22.txt, 02_rndhard_23.txt, 02_rndhard_24.txt, 02_rndhard_25.txt, 02_rndhard_26.txt, 02_rndhard_27.txt, 02_rndhard_28.txt, 02_rndhard_29.txt, 02_rndhard_30.txt, 02_rndhard_31.txt, 02_rndhard_32.txt, 02_rndhard_33.txt, 02_rndhard_34.txt, 02_rndhard_35.txt, 02_rndhard_36.txt, 02_rndhard_37.txt, 02_rndhard_38.txt, 02_rndhard_39.txt, 03_rndhardsmall_00.txt, 03_rndhardsmall_01.txt, 03_rndhardsmall_02.txt, 03_rndhardsmall_03.txt, 03_rndhardsmall_04.txt, 03_rndhardsmall_05.txt, 03_rndhardsmall_06.txt, 03_rndhardsmall_07.txt, 03_rndhardsmall_08.txt, 03_rndhardsmall_09.txt
Case Name Status Exec Time Memory
00_min_01.txt AC 368 ms 22804 KB
00_min_02.txt AC 304 ms 22672 KB
00_min_03.txt AC 305 ms 22668 KB
00_min_04.txt AC 306 ms 22664 KB
00_min_05.txt AC 306 ms 22648 KB
00_min_06.txt AC 305 ms 22684 KB
00_min_07.txt AC 305 ms 22712 KB
00_min_08.txt AC 305 ms 22660 KB
00_sample_01.txt AC 309 ms 22664 KB
00_sample_02.txt AC 311 ms 22664 KB
00_sample_03.txt AC 313 ms 22712 KB
00_sample_04.txt AC 312 ms 22660 KB
00_sample_05.txt AC 310 ms 22664 KB
01_rnd_00.txt AC 379 ms 26244 KB
01_rnd_01.txt AC 380 ms 26360 KB
01_rnd_02.txt AC 383 ms 26508 KB
01_rnd_03.txt AC 385 ms 26248 KB
01_rnd_04.txt AC 387 ms 26420 KB
01_rnd_05.txt AC 388 ms 26320 KB
01_rnd_06.txt AC 388 ms 26416 KB
01_rnd_07.txt AC 387 ms 26424 KB
01_rnd_08.txt AC 396 ms 26508 KB
01_rnd_09.txt AC 391 ms 26296 KB
01_rnd_10.txt AC 390 ms 26236 KB
01_rnd_11.txt AC 378 ms 26164 KB
01_rnd_12.txt AC 386 ms 26348 KB
01_rnd_13.txt AC 383 ms 26544 KB
01_rnd_14.txt AC 387 ms 26536 KB
01_rnd_15.txt AC 389 ms 26240 KB
01_rnd_16.txt AC 386 ms 26272 KB
01_rnd_17.txt AC 389 ms 26364 KB
01_rnd_18.txt AC 384 ms 26368 KB
01_rnd_19.txt AC 397 ms 26216 KB
02_rndhard_00.txt AC 427 ms 26376 KB
02_rndhard_01.txt AC 427 ms 26428 KB
02_rndhard_02.txt AC 391 ms 26476 KB
02_rndhard_03.txt AC 387 ms 26332 KB
02_rndhard_04.txt AC 387 ms 26508 KB
02_rndhard_05.txt AC 391 ms 26388 KB
02_rndhard_06.txt AC 387 ms 26396 KB
02_rndhard_07.txt AC 389 ms 26368 KB
02_rndhard_08.txt AC 388 ms 26292 KB
02_rndhard_09.txt AC 387 ms 26296 KB
02_rndhard_10.txt AC 384 ms 26372 KB
02_rndhard_11.txt AC 389 ms 26296 KB
02_rndhard_12.txt AC 388 ms 26308 KB
02_rndhard_13.txt AC 389 ms 26384 KB
02_rndhard_14.txt AC 391 ms 26540 KB
02_rndhard_15.txt AC 394 ms 26512 KB
02_rndhard_16.txt AC 390 ms 26244 KB
02_rndhard_17.txt AC 390 ms 26168 KB
02_rndhard_18.txt AC 393 ms 26292 KB
02_rndhard_19.txt AC 396 ms 26416 KB
02_rndhard_20.txt AC 393 ms 26320 KB
02_rndhard_21.txt AC 390 ms 26472 KB
02_rndhard_22.txt AC 395 ms 26452 KB
02_rndhard_23.txt AC 397 ms 26476 KB
02_rndhard_24.txt AC 389 ms 26292 KB
02_rndhard_25.txt AC 383 ms 26340 KB
02_rndhard_26.txt AC 386 ms 26292 KB
02_rndhard_27.txt AC 391 ms 26536 KB
02_rndhard_28.txt AC 383 ms 26288 KB
02_rndhard_29.txt AC 385 ms 26552 KB
02_rndhard_30.txt AC 384 ms 26388 KB
02_rndhard_31.txt AC 381 ms 26300 KB
02_rndhard_32.txt AC 392 ms 26296 KB
02_rndhard_33.txt AC 388 ms 26372 KB
02_rndhard_34.txt AC 391 ms 26232 KB
02_rndhard_35.txt AC 395 ms 26288 KB
02_rndhard_36.txt AC 431 ms 26304 KB
02_rndhard_37.txt AC 390 ms 26544 KB
02_rndhard_38.txt AC 393 ms 26448 KB
02_rndhard_39.txt AC 386 ms 26572 KB
03_rndhardsmall_00.txt AC 318 ms 22664 KB
03_rndhardsmall_01.txt AC 319 ms 22640 KB
03_rndhardsmall_02.txt AC 325 ms 22740 KB
03_rndhardsmall_03.txt AC 321 ms 22664 KB
03_rndhardsmall_04.txt AC 318 ms 22660 KB
03_rndhardsmall_05.txt AC 321 ms 22664 KB
03_rndhardsmall_06.txt AC 320 ms 22664 KB
03_rndhardsmall_07.txt AC 320 ms 22644 KB
03_rndhardsmall_08.txt AC 321 ms 22664 KB
03_rndhardsmall_09.txt AC 321 ms 22636 KB