Submission #420219


Source Code Expand

// standard i/o
#include <iostream>
#include <sstream>
#include <cstdio>
// standard library
#include <cstdlib>
#include <cstring>
#include <ctime>
#include <cmath>
// template class
#include <complex>
#include <string>
#include <vector>
#include <list>
#include <set>
#include <map>
#include <queue>
#include <stack>
// container control
#include <algorithm>

using namespace std;

#define rep( i, n ) for( int i = 0; i < n; ++i )
#define irep( i, n ) for( int i = n-1; i >= 0; --i )
#define reep( i, s, n ) for ( int i = s; i < n; ++i )
#define ireep( i, n, s ) for ( int i = n-1; i >= s; --i )
#define foreach(itr, x) for( typeof(x.begin()) itr = x.begin(); itr != x.end(); ++itr)

#define mp( a, b ) make_pair( a, b )
#define pb( a ) push_back( a )
#define all( v ) v.begin(), v.end()
#define fs first
#define sc second
#define vc vector

typedef long long ll;
typedef complex<double> point;

typedef pair<int, int> pii;
typedef pair<int, pii> ipii;
typedef vector<int> vi;
typedef vector<double> vd;
typedef vector< vector<int> > vii;
typedef vector< vector<double> > vdd;

typedef vector<int>::iterator vi_itr;

const int iinf = 1 << 28;
const double inf = 1e30;
const double eps = 1e-10;
const double pi = acos(-1.0);

// direction : l u r d
const int dx[] = { -1, 0, 1, 0};
const int dy[] = { 0, -1, 0, 1 };

int h, w;
char field[500][500];
bool visited[500][500];
pii start, goal;

bool search ( int x, int y )
{
	visited[y][x] = true;
	
	if( field[y][x] == 'g' ){
		return true;
	}
	
	bool ret = false;

	rep(i, 4){
		int nx = x + dx[i];
		int ny = y + dy[i];

		if( nx < 0 || nx >= w || ny < 0 || ny >= h ){
			continue;
		}
		if( visited[ny][nx] || field[ny][nx] == '#' ){
			continue;
		}

		ret |= search(nx, ny);
	}

	return ret;
}

int main()
{
	cin >> h >> w;
	rep(i, h){
		rep(j, w){
			cin >> field[i][j];
			if( field[i][j] == 's' ){
				start = mp(j, i);
			}
			else if( field[i][j] == 'g' ){
				goal = mp(j, i);
			}
		}
	}

	cout << (search(start.fs, start.sc) ? "Yes" : "No") << endl;
}

Submission Info

Submission Time
Task A - 深さ優先探索
User gyuuto
Language C++ (GCC 4.9.2)
Score 100
Code Size 2119 Byte
Status AC
Exec Time 83 ms
Memory 12452 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 25 ms 920 KB
00_min_02.txt AC 28 ms 796 KB
00_min_03.txt AC 25 ms 920 KB
00_min_04.txt AC 26 ms 732 KB
00_min_05.txt AC 26 ms 920 KB
00_min_06.txt AC 25 ms 932 KB
00_min_07.txt AC 25 ms 928 KB
00_min_08.txt AC 24 ms 928 KB
00_sample_01.txt AC 24 ms 800 KB
00_sample_02.txt AC 26 ms 796 KB
00_sample_03.txt AC 24 ms 800 KB
00_sample_04.txt AC 25 ms 928 KB
00_sample_05.txt AC 24 ms 808 KB
01_rnd_00.txt AC 48 ms 928 KB
01_rnd_01.txt AC 74 ms 10288 KB
01_rnd_02.txt AC 67 ms 4772 KB
01_rnd_03.txt AC 80 ms 12452 KB
01_rnd_04.txt AC 75 ms 9772 KB
01_rnd_05.txt AC 49 ms 1060 KB
01_rnd_06.txt AC 64 ms 3744 KB
01_rnd_07.txt AC 66 ms 4264 KB
01_rnd_08.txt AC 49 ms 936 KB
01_rnd_09.txt AC 49 ms 924 KB
01_rnd_10.txt AC 57 ms 1576 KB
01_rnd_11.txt AC 49 ms 936 KB
01_rnd_12.txt AC 73 ms 8092 KB
01_rnd_13.txt AC 71 ms 7592 KB
01_rnd_14.txt AC 48 ms 924 KB
01_rnd_15.txt AC 60 ms 2720 KB
01_rnd_16.txt AC 50 ms 932 KB
01_rnd_17.txt AC 59 ms 2340 KB
01_rnd_18.txt AC 51 ms 940 KB
01_rnd_19.txt AC 83 ms 11996 KB
02_rndhard_00.txt AC 52 ms 1052 KB
02_rndhard_01.txt AC 51 ms 1052 KB
02_rndhard_02.txt AC 54 ms 1180 KB
02_rndhard_03.txt AC 54 ms 1184 KB
02_rndhard_04.txt AC 50 ms 1052 KB
02_rndhard_05.txt AC 50 ms 1056 KB
02_rndhard_06.txt AC 49 ms 1064 KB
02_rndhard_07.txt AC 50 ms 928 KB
02_rndhard_08.txt AC 51 ms 1060 KB
02_rndhard_09.txt AC 51 ms 1056 KB
02_rndhard_10.txt AC 50 ms 1112 KB
02_rndhard_11.txt AC 50 ms 1060 KB
02_rndhard_12.txt AC 50 ms 1068 KB
02_rndhard_13.txt AC 51 ms 1056 KB
02_rndhard_14.txt AC 50 ms 1180 KB
02_rndhard_15.txt AC 51 ms 1180 KB
02_rndhard_16.txt AC 49 ms 1064 KB
02_rndhard_17.txt AC 50 ms 1056 KB
02_rndhard_18.txt AC 50 ms 1052 KB
02_rndhard_19.txt AC 55 ms 992 KB
02_rndhard_20.txt AC 52 ms 1056 KB
02_rndhard_21.txt AC 51 ms 1064 KB
02_rndhard_22.txt AC 50 ms 1048 KB
02_rndhard_23.txt AC 50 ms 1064 KB
02_rndhard_24.txt AC 48 ms 1056 KB
02_rndhard_25.txt AC 50 ms 1052 KB
02_rndhard_26.txt AC 49 ms 1056 KB
02_rndhard_27.txt AC 49 ms 1052 KB
02_rndhard_28.txt AC 53 ms 1060 KB
02_rndhard_29.txt AC 49 ms 1056 KB
02_rndhard_30.txt AC 48 ms 1056 KB
02_rndhard_31.txt AC 48 ms 1056 KB
02_rndhard_32.txt AC 48 ms 1064 KB
02_rndhard_33.txt AC 49 ms 1056 KB
02_rndhard_34.txt AC 49 ms 1052 KB
02_rndhard_35.txt AC 49 ms 1056 KB
02_rndhard_36.txt AC 49 ms 1064 KB
02_rndhard_37.txt AC 49 ms 1060 KB
02_rndhard_38.txt AC 50 ms 1056 KB
02_rndhard_39.txt AC 50 ms 1068 KB
03_rndhardsmall_00.txt AC 23 ms 928 KB
03_rndhardsmall_01.txt AC 25 ms 804 KB
03_rndhardsmall_02.txt AC 25 ms 928 KB
03_rndhardsmall_03.txt AC 25 ms 800 KB
03_rndhardsmall_04.txt AC 25 ms 924 KB
03_rndhardsmall_05.txt AC 24 ms 800 KB
03_rndhardsmall_06.txt AC 25 ms 804 KB
03_rndhardsmall_07.txt AC 24 ms 928 KB
03_rndhardsmall_08.txt AC 25 ms 804 KB
03_rndhardsmall_09.txt AC 24 ms 732 KB