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

石子合并

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

相关推荐

不愿透露姓名的神秘牛友
08-20 19:41
那一天的Java_J...:简历完全流水账,学生思维很严重,还有很大的优化空间,可以多看看牛客的简历。
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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