题解 | 显生之宙

显生之宙

https://www.nowcoder.com/practice/c2335f2530974af3a4ec15db2851f532

import java.util.*;

public class Main{
    static Scanner in = new Scanner(System.in);
    public static void solve(){
        int n = in.nextInt();
        long []a = new long[n + 1];
        for(int i = 1;i <= n;i++) a[i] = in.nextInt();
        Arrays.sort(a, 1, n+1);
        long all = 0;
        long nxt = 0;
        for(int i=1;i<=n;i++){
            a[i] += all+nxt;
            nxt = 0;
            if(a[i] < 0){
                all += a[i];
            }
            else{
                nxt += a[i];
            }
        }
        System.out.println(a[n]);
    }
    public static void main(String[] args){
        int T = in.nextInt();
        for(;T > 0;T--){
            solve();
        }
    }
}

全部评论
智齿
点赞 回复 分享
发布于 03-13 12:13 河北

相关推荐

04-03 15:12
已编辑
门头沟学院 Java
点赞 评论 收藏
分享
评论
2
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务