# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
341028 | peuch | Mecho (IOI09_mecho) | C++17 | 255 ms | 10988 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;
const int MAXN = 1010;
int dx[4] = {0, 1, 0, -1};
int dy[4] = {1, 0, -1, 0};
int n, s;
int hx, hy;
int mx, my;
char grid[MAXN][MAXN];
int beeDist[MAXN][MAXN];
int marc[MAXN][MAXN];
int dist[MAXN][MAXN];
void preCalc();
bool test(int temp);
int bb();
int main(){
scanf("%d %d", &n, &s);
for(int i = 1; i <= n; i++){
for(int j = 1; j <= n; j++){
scanf(" %c", &grid[i][j]);
if(grid[i][j] == 'D') hx = i, hy = j;
if(grid[i][j] == 'M') mx = i, my = j;
}
}
preCalc();
printf("%d\n", bb());
}
void preCalc(){
queue<int> fila;
for(int i = 1; i <= n; i++){
for(int j = 1; j <= n; j++){
if(grid[i][j] != 'H') beeDist[i][j] = 2e8;
else{
marc[i][j] = 1;
fila.push(i);
fila.push(j);
}
}
}
while(!fila.empty()){
int curx = fila.front();
fila.pop();
int cury = fila.front();
fila.pop();
for(int i = 0; i < 4; i++){
int vizx = curx + dx[i];
int vizy = cury + dy[i];
if(vizx <= 0 || vizx > n) continue;
if(vizy <= 0 || vizy > n) continue;
if(grid[vizx][vizy] == 'T') continue;
if(grid[vizx][vizy] == 'D') continue;
if(marc[vizx][vizy]) continue;
marc[vizx][vizy] = 1;
beeDist[vizx][vizy] = beeDist[curx][cury] + 1;
fila.push(vizx);
fila.push(vizy);
}
}
}
bool test(int temp){
queue<int> fila;
for(int i = 1; i <= n; i++){
for(int j = 1; j <= n; j++){
marc[i][j] = 0;
dist[i][j] = 0;
}
}
fila.push(mx);
fila.push(my);
marc[mx][my] = 1;
dist[mx][my] = 0;
while(!fila.empty()){
int curx = fila.front();
fila.pop();
int cury = fila.front();
fila.pop();
for(int i = 0; i < 4; i++){
int vizx = curx + dx[i];
int vizy = cury + dy[i];
if(vizx <= 0 || vizx > n) continue;
if(vizy <= 0 || vizy > n) continue;
if(grid[vizx][vizy] == 'T') continue;
if(temp + (dist[curx][cury] + 1) / s >= beeDist[vizx][vizy]) continue;
if(marc[vizx][vizy]) continue;
marc[vizx][vizy] = 1;
dist[vizx][vizy] = dist[curx][cury] + 1;
fila.push(vizx);
fila.push(vizy);
}
}
return marc[hx][hy];
}
int bb(){
int ini = 0, fim = 1e8 + 10;
if(!test(ini)) return -1;
while(ini != fim){
int mid = (ini + fim) >> 1;
if(ini == fim - 1) mid = fim;
if(test(mid)) ini = mid;
else fim = mid - 1;
}
return ini;
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |