AT_arc181_d [ARC181D] Prefix Bubble Sort

题目描述

给定一个 $ (1,2,\dots,N) $ 的排列 $ P=(P_1,P_2,\dots,P_N) $。 对于该排列,定义如下操作 $ k\ (k=2,3,\dots,N) $: - 操作 $ k $:依次对 $ i=1,2,\dots,k-1 $,如果 $ P_i > P_{i+1} $,则交换 $ P $ 的第 $ i $ 项和第 $ i+1 $ 项的值。 给定一个长度为 $ M $ 的**广义单调递增**数列 $ A=(A_1,A_2,\dots,A_M)\ (2 \leq A_i \leq N) $。 对于每个 $ i=1,2,\dots,M $,请你求出对 $ P $ 依次按顺序执行操作 $ A_1,A_2,\dots,A_i $ 后,排列 $ P $ 的逆序对数。 数列的逆序对数定义如下:对于长度为 $ n $ 的数列 $ x=(x_1,x_2,\dots,x_n) $,逆序对数是满足 $ 1 \leq i < j \leq n $ 且 $ x_i > x_j $ 的整数对 $ (i,j) $ 的个数。

输入格式

输入以如下格式从标准输入读入: > $ N $ $ P_1 $ $ P_2 $ $ \dots $ $ P_N $ $ M $ $ A_1 $ $ A_2 $ $ \dots $ $ A_M $

输出格式

输出 $ M $ 行。第 $ k $ 行输出 $ i=k $ 时的答案。

说明/提示

## 限制条件 - $ 2 \leq N \leq 2 \times 10^5 $ - $ 1 \leq M \leq 2 \times 10^5 $ - $ 2 \leq A_i \leq N $ - $ P $ 是 $ (1,2,\dots,N) $ 的一个排列 - 对于 $ i=1,2,\dots,M-1 $,有 $ A_i \leq A_{i+1} $ - 所有输入的值均为整数 ## 样例解释 1 首先执行操作 $ 4 $。在操作 $ 4 $ 的过程中,$ P $ 依次变为 $ (3,2,4,1,6,5)\rightarrow(2,3,4,1,6,5)\rightarrow(2,3,4,1,6,5)\rightarrow(2,3,1,4,6,5) $。操作 $ 4 $ 结束后,$ P $ 的逆序对数为 $ 3 $。接着执行操作 $ 6 $,$ P $ 最终变为 $ (2,1,3,4,5,6) $,逆序对数为 $ 1 $。 由 ChatGPT 4.1 翻译