# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
915218 | vjudge1 | Patkice (COCI20_patkice) | C++17 | 1 ms | 600 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "bits/stdc++.h"
using namespace std;
int main(){
ios_base::sync_with_stdio(0);
cin.tie(0);
long long r, c;
cin>>r>>c;
vector<string> Mapa(r);
for(long long i = 0; i < r; i++) cin>>Mapa[i];
long long Inicio_fila, Inicio_columna, Final_fila, Final_columna;
for(long long i = 0; i < r; i++){
for(long long j = 0; j < c; j++){
if(Mapa[i][j] == 'o'){
Inicio_fila = i;
Inicio_columna = j;
}
if(Mapa[i][j] == 'x'){
Final_fila = i;
Final_columna = j;
}
}
}
long long Contador = 9999999999999999;
char Respuesta = 'G';
long long Contante = 1;
long long Fila = Inicio_fila;
long long Columna = Inicio_columna + 1;
while(1){
//cout<<Fila<<" "<<Columna<<"\n";
if(Fila == Final_fila and Columna == Final_columna){
if(Contante < Contador){
Contador = Contante;
Respuesta = 'E';
}
break;
}
if(Fila == Inicio_fila and Columna == Inicio_columna) break;
bool zd = 0;
switch(Mapa[Fila][Columna]){
case '>':
Columna++;
break;
case '<':
Columna--;
break;
case '^':
Fila--;
break;
case 'v':
Fila++;
break;
case '.':
zd = 1;
break;
}
Contante++;
if(zd) break;
}
Contante = 1;
Fila = Inicio_fila - 1;
Columna = Inicio_columna;
while(1){
if(Fila == Final_fila and Columna == Final_columna){
if(Contante < Contador){
Contador = Contante;
Respuesta = 'N';
}
break;
}
if(Fila == Inicio_fila and Columna == Inicio_columna) break;
bool zd = 0;
switch(Mapa[Fila][Columna]){
case '>':
Columna++;
break;
case '<':
Columna--;
break;
case '^':
Fila--;
break;
case 'v':
Fila++;
break;
case '.':
zd = 1;
break;
}
Contante++;
if(zd) break;
}
Contante = 1;
Fila = Inicio_fila + 1;
Columna = Inicio_columna;
while(1){
if(Fila == Final_fila and Columna == Final_columna){
if(Contante < Contador){
Contador = Contante;
Respuesta = 'S';
}
break;
}
if(Fila == Inicio_fila and Columna == Inicio_columna) break;
bool zd = 0;
switch(Mapa[Fila][Columna]){
case '>':
Columna++;
break;
case '<':
Columna--;
break;
case '^':
Fila--;
break;
case 'v':
Fila++;
break;
case '.':
zd = 1;
break;
}
Contante++;
if(zd) break;
}
Contante = 1;
Fila = Inicio_fila;
Columna = Inicio_columna - 1;
while(1){
if(Fila == Final_fila and Columna == Final_columna){
if(Contante < Contador){
Contador = Contante;
Respuesta = 'W';
}
break;
}
if(Fila == Inicio_fila and Columna == Inicio_columna) break;
bool zd = 0;
switch(Mapa[Fila][Columna]){
case '>':
Columna++;
break;
case '<':
Columna--;
break;
case '^':
Fila--;
break;
case 'v':
Fila++;
break;
case '.':
zd = 1;
break;
}
Contante++;
if(zd) break;
}
if(Respuesta == 'G') cout<<":(";
else cout<<":)\n"<<Respuesta;
return 0;
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |