排序后,从大到小挨着合并就行了

石子合并

http://www.nowcoder.com/questionTerminal/3eef8d66b0fa4f71a8498974547fe670

排序后,从大到小挨着合并就行了。
数学证明:
无论怎么合并,展开括号后,都有n*(n-1)/2项多项式,
且就是每个数分别乘其它各个数,除以2去重。

import java.util.*;
public class Main{
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int[] v = new int[n];
        for(int i = 0; i < n; ++i) v[i] = sc.nextInt();
        Arrays.sort(v);
        int pre = v[n - 1], sum = 0;
        for(int i = n - 2; i >= 0; --i){
            sum += pre*v[i];
            pre += v[i];
        }
        System.out.println(sum);
    }
}
全部评论
其实都不用排序,直接挨个合并就行了,好像任何顺序都一样的。
点赞
送花
回复 分享
发布于 2020-08-29 11:12

相关推荐

1 收藏 评论
分享
牛客网
牛客企业服务