QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#864410#9851. Cup of Waterxyppyx#RE 0ms0kbC++141.2kb2025-01-20 16:16:252025-01-20 16:16:25

Judging History

你现在查看的是最新测评结果

  • [2025-01-20 16:16:25]
  • 评测
  • 测评结果:RE
  • 用时:0ms
  • 内存:0kb
  • [2025-01-20 16:16:25]
  • 提交

answer

#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;

typedef long double llf;
const int N = 1e5 + 5;
vector<llf> tree[N];
int n;
llf w[N];

int main()
{
    scanf("%d", &n);
    for(int i = 1; i <= n; i++)scanf("%llf", &w[i]);
    int x, y;
    for(int i = 1; i < n; i++)
    {
        scanf("%d %d", &x, &y);
        tree[x].push_back(w[y]);
        tree[y].push_back(w[x]);
    }
    for(int i = 1; i <= n; i++)sort(tree[i].begin(), tree[i].end());

    llf ans = -0x7f7f7f7f;
    for(int i = 1; i <= n; i++)
    {
        llf tmp1 = 0, tmp2 = 0;
        tmp1 = (1.0 * w[i] + tree[i][tree[i].size() - 1]) / 2.0;
        if(tree[i].size() > 3)
            tmp2 = (1.0 * w[i] + tree[i][tree[i].size() - 1] + tree[i][tree[i].size() - 2]) / 3.0;
        ans = max(ans, tmp1);
        ans = max(ans, tmp2);
    }
    for(int i = 1; i <= n; i++)
    {
        llf tmp1 = 0, tmp2 = 0x7f7f7f7f;
        tmp1 = (1.0 * w[i] + tree[i][0]) / 2.0;
        if(tree[i].size() > 3)
            tmp2 = (1.0 * w[i] + tree[i][0] + tree[i][1]) / 3.0;
        ans = max(ans, -tmp1);
        ans = max(ans, -tmp2);
    }
    ans = ans * ans / 4.0;
    printf("%.6llf\n", ans);
    //while(1);
    return 0;
}

详细

Test #1:

score: 0
Runtime Error

input:

2
0.3
1.5

output:


result: