#abc150e. [abc150_e]Change a Little Bit

[abc150_e]Change a Little Bit

题目描述:

对于两个长度为 nn01\texttt{01} 序列 S,TS,T ,我们定义 f(S,T)f(S,T) 为通过以下操作将 SS 修改为 TT 的最小代价和: 选择一个 SS 中的二进制位 SiS_{i} ,然后改变 SiS_{i}01\texttt{01} 状态,代价为 D×CiD \times C_{i},其中 DD 是此次操作前满足 SjTjS_{j}\ne T_{j} 的整数 jj 的数量,CiC_{i} 是一个给定的序列中的一个值。

求当 SS2n2^n 种不同的状态,TT2n2^n 种不同的状态时,f(S,T)f(S,T) 的和对 10000000071000000007 取模的结果。

输入格式:

第一行一个整数 nn

第二行 nn 个整数 CiC_{i}

输出格式:

一行一个整数,表示答案

说明/提示:

1n200000,1Ci1091 \le n \le 200000 , 1 \le C_{i} \le 10^9