結果
問題 | No.1998 Manhattan Restaurant |
ユーザー |
![]() |
提出日時 | 2022-07-01 21:59:10 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 92 ms / 2,000 ms |
コード長 | 1,690 bytes |
コンパイル時間 | 1,509 ms |
コンパイル使用メモリ | 171,252 KB |
実行使用メモリ | 5,760 KB |
最終ジャッジ日時 | 2024-11-26 04:58:40 |
合計ジャッジ時間 | 3,879 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 31 |
ソースコード
#include <bits/stdc++.h>using namespace std;const long long INF = 10000000000;int main(){int N;cin >> N;vector<int> X(N), Y(N);for (int i = 0; i < N; i++){cin >> X[i] >> Y[i];}vector<long long> S(N), D(N);for (int i = 0; i < N; i++){S[i] = X[i] + Y[i];D[i] = X[i] - Y[i];}long long mxS = -INF, mnS = INF, mxD = -INF, mnD = INF;for (int i = 0; i < N; i++){mxS = max(mxS, S[i]);mnS = min(mnS, S[i]);mxD = max(mxD, D[i]);mnD = min(mnD, D[i]);}long long tv = INF, fv = -1;while (tv - fv > 1){long long mid = (tv + fv) / 2;bool ok;if (mxS - mnS <= mid * 2 && mxD - mnD <= mid * 2){ok = true;} else if (mxS - mnS > mid * 2 && mxD - mnD > mid * 2){bool ok1 = true, ok2 = true;for (int i = 0; i < N; i++){long long d1 = max(abs(S[i] - (mnS + mid)), abs(D[i] - (mnD + mid)));long long d2 = max(abs(S[i] - (mnS + mid)), abs(D[i] - (mxD - mid)));long long d3 = max(abs(S[i] - (mxS - mid)), abs(D[i] - (mnD + mid)));long long d4 = max(abs(S[i] - (mxS - mid)), abs(D[i] - (mxD - mid)));if (d1 > mid && d4 > mid){ok1 = false;}if (d2 > mid && d3 > mid){ok2 = false;}}ok = ok1 || ok2;} else {bool ok1 = true, ok2 = true;for (int i = 0; i < N; i++){if (mnS + mid * 2 < S[i] && S[i] < mxS - mid * 2){ok1 = false;}if (mnD + mid * 2 < D[i] && D[i] < mxD - mid * 2){ok2 = false;}}ok = ok1 && ok2;}if (ok){tv = mid;} else {fv = mid;}}cout << tv << endl;}