#aBC150Eid239. E - Change a Little Bit

E - Change a Little Bit

AT_abc150_e [ABC150E] 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}

输出格式

一行一个整数,表示答案

输入输出样例 #1

输入 #1

1
1000000000

输出 #1

999999993

输入输出样例 #2

输入 #2

2
5 8

输出 #2

124

输入输出样例 #3

输入 #3

5
52 67 72 25 79

输出 #3

269312

说明/提示

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