No.1332 Range Nearest Query
レベル : / 実行時間制限 : 1ケース 2.500秒 / メモリ制限
: 512 MB / 標準ジャッジ問題
タグ : / 解いたユーザー数 84
作問者 : penguinman / テスター : yuto1115
タグ : / 解いたユーザー数 84
作問者 : penguinman / テスター : yuto1115
問題文最終更新日: 2021-01-24 01:47:23
問題文
数直線上の $N$ 個の座標 $X_1,\ X_2,\ ...,\ X_N$ が与えられます。
以下のクエリが $Q$ 個与えられるので、順に処理してください。
- $2$ 整数 $l,\ r$ と座標 $x$ が与えられる。$\min(|X_l-x|,\ |X_{l+1}-x|,\ ...,\ |X_r-x|)$ を求めよ。
注意
時間制限の厳しい問題になっております。
PyPy3 による想定解の AC は確認しておりますが($1500-2400$ms 程度)、同様のコードを Python3 で投げたところ TLE しました。
Python ユーザーの方には PyPy3 による提出を推奨します。
入力
$N$ $X_1\ X_2\ ...\ X_N$ $Q$ $l_1\ r_1\ x_1$ $l_2\ r_2\ x_2$ $:$ $l_Q\ r_Q\ x_Q$
便宜上 $i$ 番目のクエリにおける $l,\ r,\ x$ をそれぞれ $l_i,\ r_i,\ x_i$ としています。
入力は以下の制約を満たします。
- $1≤N≤3×10^5$
- $1≤Q≤10^5$
- $1≤X_i≤10^9$
- $X_i≠X_j(i≠j)$
- $1≤l_i≤r_i≤N$
- $1≤x_i≤10^9$
- 入力は全て整数
出力
$i$ 行目には、$i$ 番目のクエリに対する答えを出力してください。
サンプル
サンプル1
入力
2 1 2 3 2 2 1 1 1 3 1 2 3
出力
1 2 1
$1$ 番目のクエリでは $|X_2-1|=|2-1|$ を、
$2$ 番目のクエリでは $|X_1-3|=|1-3|$ を、
$3$ 番目のクエリでは $min(|X_1-3|,\ |X_2-3|)=min(|1-3|,\ |2-3|)$ を出力します。
サンプル2
入力
4 1 4 2 3 4 1 3 4 1 4 9 1 4 2 2 3 3
出力
0 5 0 1
サンプル3
入力
5 100 291 15 57 100000 6 1 4 343 3 3 101 4 5 3010 1 5 193 3 5 302 1 2 195
出力
52 86 2953 93 245 95
提出するには、Twitter 、GitHub、 Googleもしくは右上の雲マークをクリックしてアカウントを作成してください。