제출 #1134848

#제출 시각아이디문제언어결과실행 시간메모리
1134848duonggsimpMecho (IOI09_mecho)C++20
0 / 100
2 ms328 KiB
#include <bits/stdc++.h> using namespace std; typedef long long ll; typedef pair <ll,ll> ii; typedef pair <ii,ii> iii; #define pb push_back #define fi first #define se second #define endl '\n' #define N 1000005 #define M 1005 #define MOD 1000000007 const ll dx[] = {0,0,-1,1}; const ll dy[] = {-1,1,0,0}; ll n,s; ii u,v; ll d[M][M]; ll dist[M][M]; bool f[M][M]; bool c[M][M]; char a[M][M]; queue <ii> q1; queue <ii> q; void debug(){ for (long i=1; i<=n; i++){ for (long j=1; j<=n; j++) cerr << dist[i][j] << ' '; cerr << endl; } } bool check(ll x,ll y,ll s,ll t,ll mid){ return ((dist[x][y] + 1) / s + mid) < d[s][t]; } void setup(){ for (long i=1; i<=n; i++){ for (long j=1; j<=n; j++){ if (a[i][j] != 'H') d[i][j] = 1e18; } } while (!q1.empty()){ ii t = q1.front(); q1.pop(); for (long i=0; i<4; i++){ ll x = t.fi + dx[i]; ll y = t.se + dy[i]; if (x >= 1 && y >= 1 && x <= n && y <= n && !f[x][y] && a[x][y] != 'T' && a[x][y] != 'D'){ f[x][y] = 1; d[x][y] = min(d[x][y],d[t.fi][t.se] + 1); q1.push({x,y}); } } } } bool bfs(ll mid){ for (long i=1; i<=n; i++){ for (long j=1; j<=n; j++){ c[i][j] = 0; dist[i][j] = 1e18; } } c[u.fi][u.se] = 1; dist[u.fi][u.se] = 0; q.push({u.fi,u.se}); if (mid >= d[u.fi][u.se]) return 0; while (!q.empty()){ ii t2 = q.front(); q.pop(); for (long i=0; i<4; i++){ ll x = t2.fi + dx[i]; ll y = t2.se + dy[i]; if (x >= 1 && y >= 1 && x <= n && y <= n && dist[x][y] > dist[t2.fi][t2.se] + 1 && !c[x][y] && a[x][y] != 'T' && check(t2.fi,t2.se,x,y,mid)){ c[x][y] = 1; dist[x][y] = dist[t2.fi][t2.se] + 1; q.push({x,y}); } } } return c[v.fi][v.se]; } signed main(){ #ifndef ONLINE_JUDGE freopen("test.inp", "r", stdin); freopen("test.out" ,"w", stdout); #endif ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); cin >> n >> s; for (long i=1; i<=n; i++){ for (long j=1; j<=n; j++){ cin >> a[i][j]; if (a[i][j] == 'M'){ u.fi = i; u.se = j; } if (a[i][j] == 'D'){ v.fi = i; v.se = j; } if (a[i][j] == 'H'){ q1.push({i,j}); d[i][j] = 0; f[i][j] = 1; } } } setup(); ll l = 0, r = 800*800; ll res = -1; while (l <= r){ ll mid = l + r >> 1; if (bfs(mid)){ l = mid + 1; res = mid; } else r = mid - 1; } cout << res; return 0; }

컴파일 시 표준 에러 (stderr) 메시지

mecho.cpp: In function 'int main()':
mecho.cpp:98:12: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   98 |     freopen("test.inp", "r", stdin);
      |     ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~
mecho.cpp:99:12: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   99 |     freopen("test.out" ,"w", stdout);
      |     ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...