n只有30,O(2n)应该能行吧。然而T了
#include <bits/stdc++.h>
using namespace std;
int n, a[50];
long long ans;
void dfs(int dep, long long sum) {
	if (dep == n + 1) {
		ans += sum;
		return;
	}
	dfs(dep + 1, sum + a[dep]);
	dfs(dep + 1, sum);
}
int main() {
	n = 1;
	while (cin >> a[n]) ++n;
	--n;
	dfs(1, 0);
	cout << ans;
}