众数归于本初
生命就此苏生
白垩色的王子给了你一个由
个数组成的数列,并告诉你,你需要执行
次如下操作:
选定一个数列中的数
,再选择数列中的至少一个其他数,然后让这些数都加上
,再将
移除出这个数列。
经
次操作过后,数列中最后只会剩下一个数。白垩色的王子希望你告诉他,最后剩下的那个数最小是多少。题目保证最后输出的答案的绝对值
。
选定一个数列中的数
经
众数归于本初
生命就此苏生
第一行输入一个整数,表示数据组数。
对于每一组数据,第一行输入一个整数,表示初始数列中有
个数。
接下来一行,输入个数
,表示初始数列。
对于每一组数据,输出一行一个整数,表示最后剩下的那个数的最小值。
2 2 1 2 4 -1 8 -2 0
3 -2
对于第一组数据:一种方案是令加上
,结果为
。
对于第二组数据:一种方案是先令其他三个数各加上,数列变为
,再令其他两个数各加上
,数列变为
,最后令
加上
,结果为
。
1 6 -1 -2 -3 100 200 300
549
一种方案是先令其他五个数各加上,数列变为
,再令其他四个数各加上
,数列变为
,再令其他三个数各加上
,数列变为
,然后三个数依次加给下一个数,得到答案。
先加起来:把所有数字加起来,得到一个初始总和 ans喵,这个值将会和结果直接相关喵!
从小到大排序:把数字从小到大排排队,这样最负的数(最小的)就会先被处理。
用一个“小本本”记录影响:定义一个变量 jian(就是“减”的意思),它记录着之前所有操作已经让后面的数字总共减少了多少。一开始 jian = 0。
遍历每个数:
对于当前第 i 个数,它实际的值已经被之前的操作影响过了,所以实际值 = a[i] - jian。
如果这个实际值是负数,说明它还能用来让总和变得更小!我们就用它去加给后面所有的数(因为负数加给别人,别人会变小,总和就会减少)。
加给后面多少个数呢?后面还有 n-i-1 个数,所以这次操作会让总和增加 (后面个数 - 1) * 实际值,也就是 (n-i-2) * 实际值。因为实际值是负的,所以总和会减少。
于是 ans 加上这个值(注意是负的,所以 ans 变小)。
然后更新 jian:因为后面每个数都加了这个实际值,所以它们之后要减去的总量就变大了,jian 要减去这个实际值(实际值是负的,所以 jian 变大)。
#include <bits/stdc++.h>
#include <queue>
using namespace std;
using ll=long long;
void solve()
{
cin.tie(0)->sync_with_stdio(0);
int n;cin >> n;
vector<ll> a(n);
ll ans=0;
for(int i=0;i<n;i++)
{
cin >> a[i];
ans+=a[i];
}
sort(a.begin(),a.end());
ll jian=0;
for(int i=0;i<n;i++)
{
if(a[i]-jian<0)//如果是负数喵
{
if(n-i-2>0) ans+=(a[i]-jian)*(n-i-2);
jian-=a[i]-jian;//让jian更大喵!
}
else break;//如果是非负数就可以直接输出求和了喵
}
cout << ans << '\n';
}
int main() {
cin.tie(0)->sync_with_stdio(0);
int t;cin >> t;
while(t--) solve();
}
/*
⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⣀⣤⣤⡀⣀⣠⣤⣄⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⣀⣀⡀⢀⣴⣾⣷⣶⣾⣿⣿⣿⣿⣿⣿⣿⣿⣷⣾⣿⣷⣦⡀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⣠⣾⣿⣿⣿⣿⣿⣿⣿⠿⠛⠛⠉⠉⠉⠉⠉⠉⠛⠻⠿⣿⣿⣿⣿⣿⣶⣤⡀⠀⠀⠀⠀⠀⠀⠀⠀⠀
⠀⠀⠀⠀⠀⠀⠀⠀⢠⣾⣿⣿⣿⡿⠿⠛⠉⠉⠉⠉⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠈⠙⠿⣿⣿⣿⣷⣄⡀⠀⠀⠀⠀⠀⠀⠀
⠀⠀⠀⠀⠀⠀⠀⣀⣿⣿⣿⠟⠁⠀⠀⠀⠀⠀⠀⠀⣰⡆⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠙⠿⣿⣿⣿⡄⠀⠀⠀⠀⠀⠀
⠀⠀⠀⠀⠀⣠⣾⣿⣿⠟⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⣿⣶⣄⠀⠀⠀⠀⠀⢀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠈⣻⣿⣿⠀⠀⠀⠀⠀⠀
⠀⠀⠀⠀⠀⢹⣿⡿⠁⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⢰⣿⠁⠈⢢⡀⠀⠀⠀⢸⡇⢀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠈⠻⣿⡟⠒⢦⡀⠀⠀⠀
⠀⠀⣠⣤⣤⣼⡟⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠸⡇⠀⠀⠀⠉⢢⣄⠀⠀⢿⠊⠳⡄⠀⠀⠀⠀⠀⠀⠀⠀⠀⠙⣷⡄⠀⢷⠀⠀⠀
⠀⢰⠇⠀⣰⡟⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⡇⠀⠀⠀⠀⡌⣹⠗⠦⣬⣇⠀⠉⢢⡀⠀⠀⠀⠀⠀⠀⠀⠀⠘⣿⡀⢸⡄⠀⠀
⠀⡟⠀⣼⣯⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⢰⣆⢹⡀⠀⠀⠀⠉⠁⠀⠀⢀⣀⡁⠀⠀⠉⠳⢴⡆⠀⠀⠀⠀⠀⠀⢹⣧⠈⡇⠀⠀
⠀⡇⠀⠀⢻⣦⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⣀⣾⠻⠉⠛⠂⠀⠀⠀⠀⠀⠀⠻⠿⣿⣿⣿⣶⣦⡀⠛⣇⠀⠀⠀⠀⠀⣈⣿⠀⡇⠀⠀
⢸⡇⠀⠀⢠⣿⣷⣦⣀⡸⣷⣦⣶⡂⠉⠉⠉⢁⣤⣶⡶⠀⠀⠀⣀⣀⡴⠀⠀⠀⠀⠀⠀⠈⠉⠉⠁⠀⡟⢀⣴⣟⣰⣾⣿⣏⣠⠇⠀⠀
⠈⡇⠀⠀⢸⣿⠁⠉⣿⠛⠛⠃⡇⠀⠀⢠⣶⣿⡿⠛⠁⠀⠀⠉⠁⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠼⢿⠟⠿⢿⡏⠀⠘⣿⡀⠀⠀⠀
⠀⢷⣀⣀⣿⠇⠀⠀⢿⡇⠀⢀⢱⡀⠀⠛⠛⠉⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⣼⠀⠀⢸⠇⠀⠀⢹⣿⣄⠀⠀
⠀⠀⣉⣿⡏⠀⠀⠀⠀⠀⠀⢸⣇⣳⡄⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⡰⣿⠃⠀⠀⠀⠀⠀⠀⣿⠈⢧⠀
⠀⠘⣿⣿⠁⠀⠀⠀⠀⠀⠀⠘⣿⡛⣶⠀⠀⣠⠔⠒⠛⠒⠦⡀⠀⠀⠀⠀⣠⡤⠶⠤⢤⣀⠀⠀⠀⢀⣏⡄⠀⠀⠀⠀⠀⡀⣿⡆⠈⣧
⣠⡾⠛⣿⣿⣧⠀⠀⠀⠀⢸⣿⠾⢿⡿⠀⣰⠃⠀⠀⠀⠀⠀⢹⡄⠀⠀⡼⠁⠀⠀⠀⠀⠈⠙⣦⠀⢸⣿⡇⣾⣣⡀⠀⢰⣿⣿⣿⣤⠾
⡟⠀⠀⠻⣿⡟⢷⡄⣤⡀⠈⣿⡀⣸⠇⠀⠏⠀⠀⠀⠀⠀⠀⠀⡇⠀⠀⡇⢀⡀⠀⠀⠀⠀⢀⡟⠀⠀⠋⣿⣿⣿⡇⣠⣿⠿⠛⢷⡀⠀
⠀⠀⠀⠀⣿⣇⣨⣿⣿⣿⣦⣽⣷⡟⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠁⠀⠀⠃⠀⠙⠢⠤⠤⠴⢾⠀⠀⠀⠀⢸⣷⣿⣿⠟⠁⠀⠀⠈⣧⠀
⠀⠀⠀⠀⠈⠉⠉⠁⠈⠉⠈⢉⣿⡁⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠈⠀⠀⠀⠀⢸⡇⠀⠀⠀⠀⠀⠀⠀⣿⠀
*/ Arrays.sort(array);
long delta = 0;
int index = 0;
long ans = 0;
while (index < n - 1 && array[index] + delta < 0) {
delta = delta * 2 + array[index++];
}
while (index < n) {
ans += array[index++] + delta;
}
System.out.println(ans);