오름차순으로 정렬을 해주면 각각 자기 차례가 올때까지 최소 합 시간이 걸리기 때문에 오름차순으로 정렬을 해준후 자기 순서까지 더한 값의 합을 계산해서 출력을 해주면 될 것 같다.
#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
int main(){
int n; cin >> n;
vector<int> p(n);
for(int i = 0;i < n;i++)
cin >> p[i];
sort(p.begin(), p.end());
int sum = 0;
for(int i = 0;i < p.size();i++){
for(int j = 0;j <= i;j++){
sum += p[j];
}
}
cout << sum << endl;
}