結果

問題 No.1998 Manhattan Restaurant
ユーザー HIR180HIR180
提出日時 2022-07-02 01:08:46
言語 C++17
(gcc 13.3.0 + boost 1.87.0)
結果
AC  
実行時間 29 ms / 2,000 ms
コード長 592 bytes
コンパイル時間 145 ms
コンパイル使用メモリ 28,544 KB
最終ジャッジ日時 2025-01-30 03:42:03
ジャッジサーバーID
(参考情報)
judge3 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 31
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:7:14: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
    7 |         scanf("%lld",&n);
      |         ~~~~~^~~~~~~~~~~
main.cpp:9:22: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
    9 |                 scanf("%lld%lld",&a,&b);
      |                 ~~~~~^~~~~~~~~~~~~~~~~~

ソースコード

diff #

#include <stdio.h>
#define int long long
int max(int a,int b){ return a<b?b:a;}
int min(int a,int b){ return a>b?b:a;}
int n,xs=9e9,ys=9e9,xb=-9e9,yb=-9e9,ret=9e9,x[100005],y[100005],v;
signed main(){
	scanf("%lld",&n);
	for(int i=0,a,b;i<n;i++){
		scanf("%lld%lld",&a,&b);
		x[i]=a-b; y[i]=a+b;
		xs=min(xs,x[i]); xb=max(xb,x[i]);
		ys=min(ys,y[i]); yb=max(yb,y[i]);
	}
	for(int i=0;i<n;i++) v=max(v,min(max(x[i]-xs,y[i]-ys),max(xb-x[i],yb-y[i]))); ret=min(ret,v);v=0;
	for(int i=0;i<n;i++) v=max(v,min(max(x[i]-xs,yb-y[i]),max(xb-x[i],y[i]-ys)));
	ret=min(ret,v);
	printf("%lld\n",ret/2);
}
0