# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
1050702 | kvintsekstakord | Mecho (IOI09_mecho) | C++17 | 99 ms | 5212 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 N, S;
char forest[810][810];
int btime[810][810];
bool visited[810][810];
int dx[]={1, -1, 0, 0};
int dy[]={0, 0, 1, -1};
struct src{
int x, y;
int step;
src(int x, int y, int step) : x(x), y(y), step(step){};
};
int32_t main()
{
cin >> N >> S;
queue<src> bfs;
int si, sj;
int hi, hj;
for(int i = 1; i <= N; i++){
for(int j = 1; j <= N; j++){
cin >> forest[i][j];
btime[i][j]=1e9;
if(forest[i][j]=='H'){
bfs.push(src(i, j, 0));
btime[i][j]=0;
}
if(forest[i][j]=='M'){
si = i;
sj = j;
}
if(forest[i][j]=='D'){
hi=i; hj=j;
}
}
}
while(!bfs.empty()){
int x = bfs.front().x;
int y = bfs.front().y;
int step = bfs.front().step;
bfs.pop();
for(int i = 0; i < 4; i++){
int nx = x+dx[i];
int ny = y+dy[i];
if(nx<1 || nx>N || ny<1 || ny>N) continue;
if(forest[nx][ny]=='T' || forest[nx][ny]=='D') continue;
if(step+1<btime[nx][ny]){
btime[nx][ny]=(step+1);
bfs.push(src(nx, ny, step+1));
}
}
}
for(int i = 1; i <= N; i++){
for(int j = 1; j <= N; j++){
if(btime[i][j]==1e9){
//cout << "x "; continue;
};
btime[i][j]*=S;
//cout << btime[i][j] << " ";
}//cout << endl;
}
int lo = 0;
int hig = 2000000;
lo--;
while(lo<hig){
int mid = lo+(hig-lo+1)/2;
queue<src> bfs2;
memset(visited, false, sizeof(visited));
visited[si][sj]=true;
bfs2.push({si, sj, mid*S});
bool possible = false;
while(!bfs2.empty()){
int x = bfs2.front().x;
int y = bfs2.front().y;
int step = bfs2.front().step;
bfs2.pop();
for(int i = 0; i < 4; i++){
int nx = x+dx[i];
int ny = y+dy[i];
if(nx<1 || nx>N || ny<1 || ny>N) continue;
if(forest[nx][ny]=='T') continue;
if(forest[nx][ny]=='D'){
possible = true;
break;
}
if(visited[nx][ny]) continue;
if( step+1<btime[nx][ny]){
visited[nx][ny]=true;
bfs2.push(src(nx, ny, step+1));
}
}
if(possible) break;
}
if(possible){
lo = mid;
}else{
hig = mid-1;
}
}
cout << lo;
return 0;
}
Compilation message (stderr)
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
Fetching results... |