atcoder#ABC130F. [ABC130F] Minimum Bounding Box

[ABC130F] Minimum Bounding Box

配点 : 600600

問題文

二次元平面に NN 個の点があります。ii 番目の点の初期座標は (xi,yi)(x_i, y_i) です。それぞれの点はこれから秒速 11 で同時に移動を始めます。点の移動方向は全て xx 軸または yy 軸に平行です。具体的には ii 番目の点の移動方向は文字 did_i によって与えられ、

  • di=d_i = R のとき xx 軸正方向
  • di=d_i = L のとき xx 軸負方向
  • di=d_i = U のとき yy 軸正方向
  • di=d_i = D のとき yy 軸負方向

です。

あなたは点が移動を開始して以降、任意のタイミングで全ての点の動きを止めることができます (移動開始 00 秒後に止めることも可能です)。 動きを止めたあとの NN 点の xx 座標のうち最大のものを xmaxx_{max}、最小のものを xminx_{min}yy 座標のうち最大のものを ymaxy_{max}、最小のものを yminy_{min} とします。

(xmaxxmin)×(ymaxymin)(x_{max} - x_{min}) \times (y_{max} - y_{min}) としてありうる値の最小値を求めて出力してください。

制約

  • 1N1051 \leq N \leq 10^5
  • 108xi, yi108-10^8 \leq x_i,\ y_i \leq 10^8
  • xix_i,  yi\ y_i はともに整数である。
  • did_iR, L, U, D のいずれかである。

入力

入力は以下の形式で標準入力から与えられる。

NN

x1x_1 y1y_1 d1d_1

x2x_2 y2y_2 d2d_2

..

..

..

xNx_N yNy_N dNd_N

出力

(xmaxxmin)×(ymaxymin)(x_{max} - x_{min}) \times (y_{max} - y_{min}) としてありうる値の最小値を出力せよ。

ジャッジプログラムの出力との絶対誤差または相対誤差が 10910^{-9} 以下のとき正解とみなされる。

2
0 3 D
3 0 L
0

33 秒後に 22 つの点は原点で重なり、このとき題意の値は 00 になります。

5
-7 -10 U
7 -6 U
-8 7 D
-3 3 D
0 -6 R
97.5

出力が整数にならない場合もあります。

20
6 -10 R
-4 -9 U
9 6 D
-3 -2 R
0 7 D
4 5 D
10 -10 U
-1 -8 U
10 -6 D
8 -5 U
6 4 D
0 3 D
7 9 R
9 -4 R
3 10 D
1 9 U
1 -6 U
9 -8 R
6 7 D
7 -3 D
273