AT_abc283_f [ABC283F] Permutation Distance
题目描述
给定一个 $ (1,2,\ldots,N) $ 的排列 $ P=(P_1,P_2,\ldots,P_N) $。
对于所有 $ i\ (1\leq i\leq N) $,请计算以下的值:
- $ D_i = \displaystyle\min_{j\neq i}\left( |P_i - P_j| + |i - j| \right) $
排列是指将 $ (1,2,\ldots,N) $ 重新排列得到的数列。也就是说,长度为 $ N $ 的数列 $ A $,当且仅当 $ i\ (1\leq i\leq N) $ 在其中恰好出现一次时,$ A $ 是 $ (1,2,\ldots,N) $ 的一个排列。
输入格式
输入以以下格式从标准输入读入。
> $ N\ P_1\ P_2\ \ldots\ P_N $
输出格式
请按 $ i $ 的升序,用空格分隔输出 $ D_i\ (1\leq i\leq N) $。
说明/提示
### 限制条件
- $ 2 \leq N \leq 2\times 10^5 $
- $ 1 \leq P_i \leq N\ (1\leq i\leq N) $
- $ i\neq j \implies P_i\neq P_j $
- 输入均为整数
### 样例解释 1
例如,对于 $ i=1 $:
- 当 $ j=2 $ 时,$ |P_i - P_j|=1,\ |i-j|=1 $。
- 当 $ j=3 $ 时,$ |P_i - P_j|=1,\ |i-j|=2 $。
- 当 $ j=4 $ 时,$ |P_i - P_j|=2,\ |i-j|=3 $。
因此,当 $ j=2 $ 时 $ |P_i - P_j|+|i-j|=2 $,为最小值,所以 $ D_1=2 $。
由 ChatGPT 4.1 翻译