Submission #115742

# Submission time Handle Problem Language Result Execution time Memory
115742 2019-06-08T19:59:33 Z Leonardo_Paes Portal (COCI17_portal) C++11
96 / 120
97 ms 24556 KB
#include <bits/stdc++.h>
#define MAXN 610
using namespace std;

typedef pair < int, int > ii;
typedef pair < int, ii > iii;

int n, m, val[MAXN][MAXN], c, f, vist[MAXN*MAXN];
char mat[MAXN][MAXN];

int l[MAXN][MAXN], r[MAXN][MAXN], u[MAXN][MAXN], d[MAXN][MAXN];

vector < int > grafo[MAXN*MAXN];

int bfs()
{
	queue < ii > fila;
	fila.push({c, 1});

	while(fila.size())
	{
		ii u = fila.front();
		fila.pop();
		int v = u.first;
		int d = u.second;

		if(vist[v]) continue;
		vist[v] = d;

		//cout << v << ' ' << d << endl;
		if(v == f) return d;

		for(int i = 0 ; i < grafo[v].size() ; i++)
		{
			int at = grafo[v][i];
			if(!vist[at]) fila.push({at, d+1});
		}
	}

	return -1;
}

int main()
{
	cin >> n >> m;
	int cont = 1;
	for(int i = 1 ; i <= n ; i++)
	{
		for(int j = 1 ; j <= m ; j++)
		{
			cin >> mat[i][j];
			val[i][j] = cont++;
			if(mat[i][j] == 'C') c = cont-1;
			else if(mat[i][j] == 'F') f = cont-1;
		}
	}

	// vizinhos esquerda

	int last =0;

	for(int i=1; i<=n; i++){
		for(int j=1; j<=m; j++){
			if(mat[i][j]=='#'){
				last=j;
			}
			else{
				if(mat[i+1][j]=='#')l[i][j]=val[i][last+1];
				if(mat[i-1][j]=='#')l[i][j]=val[i][last+1];
				if(mat[i][j+1]=='#')l[i][j]=val[i][last+1];
				if(mat[i][j-1]=='#')l[i][j]=val[i][last+1];
			}
		}
	}

	// vizinhos direita

	for(int i=1; i<=n; i++){
		for(int j=m; j>=1; j--){
			if(mat[i][j]=='#'){
				last=j;
			}
			else{
				if(mat[i+1][j]=='#')r[i][j]=val[i][last-1];
				if(mat[i-1][j]=='#')r[i][j]=val[i][last-1];
				if(mat[i][j+1]=='#')r[i][j]=val[i][last-1];
				if(mat[i][j-1]=='#')r[i][j]=val[i][last-1];
			}
		}
	}

	// vizinhos cima

	for(int j=1; j<=m; j++){
		for(int i=1; i<=n; i++){
			if(mat[i][j]=='#'){
				last=i;
			}
			else{
				if(mat[i+1][j]=='#')u[i][j]=val[last+1][j];
				if(mat[i-1][j]=='#')u[i][j]=val[last+1][j];
				if(mat[i][j+1]=='#')u[i][j]=val[last+1][j];
				if(mat[i][j-1]=='#')u[i][j]=val[last+1][j];
			}
		}
	}


	// vizinhos baixo

	for(int j=1; j<=m; j++){
		for(int i=n; i>=1; i--){
			if(mat[i][j]=='#'){
				last=i;
			}
			else{
				if(mat[i+1][j]=='#')d[i][j]=val[last-1][j];
				if(mat[i-1][j]=='#')d[i][j]=val[last-1][j];
				if(mat[i][j+1]=='#')d[i][j]=val[last-1][j];
				if(mat[i][j-1]=='#')d[i][j]=val[last-1][j];
			}
		}
	}

	for(int i=1; i<=n; i++){
		for(int j=1; j<=m; j++){
			if(mat[i][j]=='#')continue;
			if(mat[i+1][j]!='#')grafo[val[i][j]].push_back(val[i+1][j]);
			if(mat[i-1][j]!='#')grafo[val[i][j]].push_back(val[i-1][j]);
			if(mat[i][j+1]!='#')grafo[val[i][j]].push_back(val[i][j+1]);
			if(mat[i][j-1]!='#')grafo[val[i][j]].push_back(val[i][j-1]);
			
			if(mat[i+1][j]=='#')
			{
				grafo[val[i][j]].push_back(r[i][j]);
				grafo[val[i][j]].push_back(d[i][j]);
				grafo[val[i][j]].push_back(l[i][j]);
				grafo[val[i][j]].push_back(u[i][j]);
			}
			else if(mat[i-1][j]=='#'){
				grafo[val[i][j]].push_back(r[i][j]);
				grafo[val[i][j]].push_back(d[i][j]);
				grafo[val[i][j]].push_back(l[i][j]);
				grafo[val[i][j]].push_back(u[i][j]);
			}
			else if(mat[i][j+1]=='#'){
				grafo[val[i][j]].push_back(r[i][j]);
				grafo[val[i][j]].push_back(d[i][j]);
				grafo[val[i][j]].push_back(l[i][j]);
				grafo[val[i][j]].push_back(u[i][j]);
			}
			else if(mat[i][j-1]=='#'){
				grafo[val[i][j]].push_back(r[i][j]);
				grafo[val[i][j]].push_back(d[i][j]);
				grafo[val[i][j]].push_back(l[i][j]);
				grafo[val[i][j]].push_back(u[i][j]);
			}
		}
	}

	/*for(int i = 1 ; i <= n ; i++)
	{
		for(int j = 1 ; j <= m ; j++)
		{
			cout << "VERT: " << i << ' ' << j << endl;
			for(int k = 0 ; k < grafo[val[i][j]].size() ; k++)
			{
				cout << grafo[val[i][j]][k] << ' ';
			}
			cout << endl;
		}
	}*/

	vist[0] = 1;
	int resp = bfs();

	if(resp == -1) cout << "nemoguce\n";
	else cout << resp-1 << endl;
}

Compilation message

portal.cpp: In function 'int bfs()':
portal.cpp:33:21: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
   for(int i = 0 ; i < grafo[v].size() ; i++)
                   ~~^~~~~~~~~~~~~~~~~
# Verdict Execution time Memory Grader output
1 Correct 9 ms 9088 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 9 ms 9216 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 9 ms 9216 KB Output is correct
2 Correct 9 ms 9216 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 9 ms 9216 KB Output is correct
2 Correct 9 ms 9216 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 9 ms 9316 KB Output is correct
2 Correct 9 ms 9344 KB Output is correct
3 Correct 9 ms 9216 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 17 ms 12160 KB Output is correct
2 Correct 15 ms 10880 KB Output is correct
3 Correct 17 ms 11108 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 29 ms 12928 KB Output is correct
2 Correct 19 ms 12288 KB Output is correct
3 Correct 21 ms 11776 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 61 ms 19192 KB Output is correct
2 Correct 42 ms 15760 KB Output is correct
3 Correct 37 ms 15864 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 90 ms 22396 KB Output is correct
2 Correct 65 ms 20700 KB Output is correct
3 Correct 61 ms 17884 KB Output is correct
4 Incorrect 48 ms 18244 KB Output isn't correct
# Verdict Execution time Memory Grader output
1 Incorrect 97 ms 24556 KB Output isn't correct
2 Halted 0 ms 0 KB -