AT_arc054_d [ARC054D] バブルソート

题目描述

高中生高桥每年在他的生日上都会收到一串数字序列。高桥喜欢计算冒泡排序所需的交换次数,以前几年,他总能轻松地计算出他收到的序列的交换次数。 但是,今年高桥的妈妈做了一些不同的事情。她给了他一个高度压缩的序列,即使是高桥,通常可以在几秒内计算出长度为 $10^7$ 的序列的冒泡排序交换次数,也觉得具有挑战性。 你的任务是找出对于这个长度为 $ 10^7 $ 的序列进行冒泡排序后,将交换次数模 $ 10^9+7 $ 后的结果。 冒泡排序是根据以下伪代码给出的算法。 ```cpp input: a[1],...,a[N] for i=1 to N-1 { for j=1 to N-i { if a[j]>a[j+1] swap(a[j],a[j+1]) } } ``` 另外,从压缩列中恢复原始数列的方法如下: 1. 指针指向压缩列的第一个项,堆栈为空。以下操作将重复进行,直到指针超出压缩列。最后,堆栈中剩下的一个数列就是所需的数列。 1. 如果指针指向的值是正的,将一个只包含该值的数列推入堆栈,并将指针向前移动一步。 1. 如果指针指向的值是 $0$ ,从堆栈中取出第一个和第二个数列,将它们连接在一起,然后将结果数列推入堆栈,并将指针向前移动一步。 1. 如果指针指向的值是负的,从堆栈中取出顶部的数列,重复它 "指针指向的值" 次,然后将结果数列推入堆栈,并将指针向前移动一步。 例如,序列 ``` 1 2 3 0 -4 5 0 0 -2 ``` 表示序列 ``` 1 2 3 2 3 2 3 2 3 5 1 2 3 2 3 2 3 2 3 5 ```

输入格式

数据将以以下标准格式输入 > $ N $ $ A_1 $ ... $ A_N $

输出格式

计算其代表的数列的冒泡排序交换次数模$10^9+7$

说明/提示

- $ N\ >\ 0 $ - $ -10^5\ ≦\ A_i\ ≦\ 10^5(1\ ≦\ i\ ≦\ N) $ - $ A_i\ ≠\ 0 $ 的个数不会超过 $10^5$ 。 - 保证有解。 - 输入都是整数。 ### 部分点 这个问题设置了部分分。 - 如果在不超过 $2000$ 个非零元素的数据集上正确解决了压缩列的问题,您将获得部分分数,共计 $50$ 分。