913. 排队打水

913. 排队打水

有 n 个人排队到 1 个水龙头处打水,第 i 个人装满水桶所需的时间是 ti,请问如何安排他们的打水顺序才能使所有人的等待时间之和最小?

输入格式

第一行包含整数 n。

第二行包含 n 个整数,其中第 i 个整数表示第 i 个人装满水桶所花费的时间 ti。

输出格式

输出一个整数,表示最小的等待时间之和。

数据范围

1≤n≤105,
1≤ti≤104

输入样例:
7
3 6 1 4 2 5 7
输出样例:
56
代码:
#include 
using namespace std;const int N = 1e5 + 10;
int t[N];
typedef long long LL;
int main()
{int n;cin >> n;for (int i = 0; i < n; i++)cin >> t[i];sort(t, t + n);reverse(t, t + n);LL res = 0;for (int i = 0; i < n; i++)res += t[i] * i;cout << res << endl;return 0;
}


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部