101504: [AtCoder]ABC150 E - Change a Little Bit

Memory Limit:256 MB Time Limit:2 S
Judge Style:Text Compare Creator:
Submit:0 Solved:0

Description

Score : $500$ points

Problem Statement

For two sequences $S$ and $T$ of length $N$ consisting of $0$ and $1$, let us define $f(S, T)$ as follows:

  • Consider repeating the following operation on $S$ so that $S$ will be equal to $T$. $f(S, T)$ is the minimum possible total cost of those operations.

    • Change $S_i$ (from $0$ to $1$ or vice versa). The cost of this operation is $D \times C_i$, where $D$ is the number of integers $j$ such that $S_j \neq T_j (1 \leq j \leq N)$ just before this change.

There are $2^N \times (2^N - 1)$ pairs $(S, T)$ of different sequences of length $N$ consisting of $0$ and $1$. Compute the sum of $f(S, T)$ over all of those pairs, modulo $(10^9+7)$.

Constraints

  • $1 \leq N \leq 2 \times 10^5$
  • $1 \leq C_i \leq 10^9$
  • All values in input are integers.

Input

Input is given from Standard Input in the following format:

$N$
$C_1$ $C_2$ $\cdots$ $C_N$

Output

Print the sum of $f(S, T)$, modulo $(10^9+7)$.


Sample Input 1

1
1000000000

Sample Output 1

999999993

There are two pairs $(S, T)$ of different sequences of length $2$ consisting of $0$ and $1$, as follows:

  • $S = (0), T = (1):$ by changing $S_1$ to $1$, we can have $S = T$ at the cost of $1000000000$, so $f(S, T) = 1000000000$.
  • $S = (1), T = (0):$ by changing $S_1$ to $0$, we can have $S = T$ at the cost of $1000000000$, so $f(S, T) = 1000000000$.

The sum of these is $2000000000$, and we should print it modulo $(10^9+7)$, that is, $999999993$.


Sample Input 2

2
5 8

Sample Output 2

124

There are $12$ pairs $(S, T)$ of different sequences of length $3$ consisting of $0$ and $1$, which include:

  • $S = (0, 1), T = (1, 0)$

In this case, if we first change $S_1$ to $1$ then change $S_2$ to $0$, the total cost is $5 \times 2 + 8 = 18$. We cannot have $S = T$ at a smaller cost, so $f(S, T) = 18$.


Sample Input 3

5
52 67 72 25 79

Sample Output 3

269312

Input

题意翻译

### 题目描述: 对于两个长度为 $n$ 的 $\texttt{01}$ 序列 $S,T$ ,我们定义 $f(S,T)$ 为通过以下操作将 $S$ 修改为 $T$ 的最小代价和: 选择一个 $S$ 中的二进制位 $S_{i}$ ,然后改变 $S_{i}$ 的 $\texttt{01}$ 状态,代价为 $D \times C_{i}$,其中 $D$ 是此次操作前满足 $S_{j}\ne T_{j}$ 的整数 $j$ 的数量,$C_{i}$ 是一个给定的序列中的一个值。 求当 $S$ 取 $2^n$ 种不同的状态,$T$ 取 $2^n$ 种不同的状态时,$f(S,T)$ 的和对 $1000000007$ 取模的结果。 ### 输入格式: 第一行一个整数 $n$ 第二行 $n$ 个整数 $C_{i}$ ### 输出格式: 一行一个整数,表示答案 ### 说明/提示: $1 \le n \le 200000 , 1 \le C_{i} \le 10^9 $

加入题单

算法标签: