//Normal #define _GLIBCXX_DEBUG #define ll long long #include using namespace std; using Graph = vector>; void print(auto a){ cout << a; } void prints(auto a){ cout << a << " "; } void prints(){ cout << " "; } void printl(auto a){ cout << a << endl; } void printl(){ cout << endl; } void fix(int n){ cout << fixed << setprecision(n); } int main(){ int N; cin >> N; vector X(N); for(int i = 0; i < N; i++) cin >> X[i]; sort(X.rbegin(), X.rend()); ll ans = 0; int f = 0; int lest = pow(2, f); for(int i = 0; i < N; i++){ ans += X[i]*f; lest--; if(lest == 0){ f++; lest = pow(2, f); } } printl(ans); return 0; }