답안 #496409

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
496409 2021-12-21T07:35:49 Z Ierus Nautilus (BOI19_nautilus) C++17
66 / 100
1000 ms 74052 KB
#include<bits/stdc++.h>
/*
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
using namespace __gnu_pbds;
*/
using namespace std;
#pragma GCC optimize ("unroll-loops,Ofast,O3")
#pragma GCC target("avx,avx2,fma")
#define F first
//#define int 
#define S second
#define sz(x) (int)x.size()
#define pb push_back
#define eb emplace_back
#define all(x) (x).begin(),(x).end()
#define rall(x) (x).rbegin(),(x).rend()
#define NFS ios_base::sync_with_stdio(0) , cin.tie(0) , cout.tie(0) ;
#define file(s) if (fopen(s".in", "r")) freopen(s".in", "r", stdin), freopen(s".out", "w", stdout)
//#define ordered_set tree<int, null_type,less<int>, rb_tree_tag,tree_order_statistics_node_update>
typedef long long ll;
const int E = 1e9;
const long long inf = 1e18+777;
const int N = 5555;
const int MOD = 1e9+7;
const bool I = 1;
const vector<pair<int,int>> dxy = {{1,0},{-1,0},{0,1},{0,-1}};
int n, m, k, q[5555];
char a[555][555];
bool vis[555][555];
bool used[555][555][555];
bool In(int x, int y){
	return (x <= n && x >= 1 && y <= m && y >= 1);
}
void bfs(int x, int y, int d = 1){
	deque<tuple<int,int,int>> dq;
	dq.pb({x, y, d});
	while(!dq.empty()){
		tie(x, y, d) = dq.front();
		dq.pop_front();
		if(d == k + 1){
			vis[x][y] = true;
			continue;	
		}
		if(q[d] == -1){
			for(auto [f, s] : dxy){
				int x1 = x + f, y1 = y + s;
				if(In(x1, y1) && a[x1][y1] != '#' && !used[x1][y1][d+1]){
					dq.pb({x1, y1, d+1});
					used[x1][y1][d+1] = true;
				}
			}
		}else{
			int x1 = x + dxy[q[d]].F, y1 = y + dxy[q[d]].S;
			if(In(x1, y1) && a[x1][y1] != '#' && !used[x1][y1][d+1]){
				dq.pb({x1, y1, d+1});
				used[x1][y1][d+1] = true;
			}
		}
	}
}
signed main(){
	cin >> n >> m >> k;
	for(int i = 1; i <= n; ++i){
		for(int j = 1; j <= m; ++j){
			cin >> a[i][j];
		}
	}
	for(int i = 1; i <= k; ++i){
		char r; cin >> r;
		if(r == '?') q[i] = -1;
		if(r == 'N') q[i] = 1;
		if(r == 'S') q[i] = 0;
		if(r == 'E') q[i] = 2;
		if(r == 'W') q[i] = 3;
	}
	int res = 0;
	for(int i = 1; i <= n; ++i)
		for(int j = 1; j <= m; ++j){
			if(a[i][j] == '.'){
				bfs(i, j, 1);
			}
		}
	for(int i = 1; i <= n; ++i){
		for(int j = 1; j <= m; ++j){
			if(a[i][j] == '#'){
//				cout << "#";
			}else{
//				if(vis[i][j]) cerr << "o";
//				else cerr << "x";
				res += vis[i][j];
			}
		}
//		cerr << '\n';
	}
	cout << res;
};











# 결과 실행 시간 메모리 Grader output
1 Correct 23 ms 6220 KB Output is correct
2 Correct 5 ms 6092 KB Output is correct
3 Correct 4 ms 5708 KB Output is correct
4 Correct 5 ms 4684 KB Output is correct
5 Correct 2 ms 1868 KB Output is correct
6 Correct 1 ms 332 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 23 ms 6220 KB Output is correct
2 Correct 5 ms 6092 KB Output is correct
3 Correct 4 ms 5708 KB Output is correct
4 Correct 5 ms 4684 KB Output is correct
5 Correct 2 ms 1868 KB Output is correct
6 Correct 1 ms 332 KB Output is correct
7 Correct 24 ms 6248 KB Output is correct
8 Correct 9 ms 5964 KB Output is correct
9 Correct 5 ms 4940 KB Output is correct
10 Correct 3 ms 3148 KB Output is correct
11 Correct 1 ms 332 KB Output is correct
12 Correct 27 ms 6284 KB Output is correct
13 Correct 30 ms 6220 KB Output is correct
14 Correct 23 ms 6084 KB Output is correct
15 Correct 4 ms 3276 KB Output is correct
16 Correct 1 ms 332 KB Output is correct
17 Correct 29 ms 6192 KB Output is correct
18 Correct 34 ms 6136 KB Output is correct
19 Correct 12 ms 5568 KB Output is correct
20 Correct 5 ms 3276 KB Output is correct
21 Correct 1 ms 332 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 23 ms 6220 KB Output is correct
2 Correct 5 ms 6092 KB Output is correct
3 Correct 4 ms 5708 KB Output is correct
4 Correct 5 ms 4684 KB Output is correct
5 Correct 2 ms 1868 KB Output is correct
6 Correct 1 ms 332 KB Output is correct
7 Correct 24 ms 6248 KB Output is correct
8 Correct 9 ms 5964 KB Output is correct
9 Correct 5 ms 4940 KB Output is correct
10 Correct 3 ms 3148 KB Output is correct
11 Correct 1 ms 332 KB Output is correct
12 Correct 27 ms 6284 KB Output is correct
13 Correct 30 ms 6220 KB Output is correct
14 Correct 23 ms 6084 KB Output is correct
15 Correct 4 ms 3276 KB Output is correct
16 Correct 1 ms 332 KB Output is correct
17 Correct 29 ms 6192 KB Output is correct
18 Correct 34 ms 6136 KB Output is correct
19 Correct 12 ms 5568 KB Output is correct
20 Correct 5 ms 3276 KB Output is correct
21 Correct 1 ms 332 KB Output is correct
22 Execution timed out 1098 ms 74052 KB Time limit exceeded
23 Halted 0 ms 0 KB -