답안 #854680

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
854680 2023-09-28T13:45:33 Z boris_mihov Seesaw (JOI22_seesaw) C++17
0 / 100
1 ms 348 KB
#include <algorithm>
#include <iostream>
#include <iomanip>
#include <numeric>
#include <cassert>
#include <vector>

typedef long long llong;
const int MAXN = 200000 + 10;
const double EPS = 1e-10;
const int INF  = 1e9;

int n;
int a[MAXN];

int check2(long double l, long double r)
{
    llong sum = 0;
    for (int i = 1 ; i <= n ; ++i)
    {
        sum += a[i];
    }

    int lPtr = 1, rPtr = n;
    while (lPtr <= rPtr)
    {
        if (sum / (double)(rPtr - lPtr + 1) < l - EPS || sum / (double)(rPtr - lPtr + 1) > r + EPS)
        {
            return false;
        }

        if (lPtr == rPtr)
        {
            break;
        }

        if ((sum - a[rPtr]) / (double)(rPtr - lPtr) >= l)
        {
            sum -= a[rPtr];
            rPtr--;
        } else
        {
            sum -= a[lPtr];
            lPtr++;
        }
    }

    return true;
}

bool check(long double w)
{
    for (int i = 1 ; i <= n ; ++i)
    {
        llong sum = 0;
        for (int j = i ; j <= n ; ++j)
        {
            sum += a[j];
            if (check2(sum / (long double)(j - i + 1), sum / (long double)(j - i + 1) + w))
            {
                return true;
            }
        }
    }

    return false;
}

void solve()
{
    long double l = 0.0, r = INF, mid;
    for (int i = 0 ; i < 100 ; ++i)
    {
        mid = (l + r) / 2.0;
        if (!check(mid)) l = mid;
        else r = mid;
    }

    std::cout << std::fixed << std::setprecision(10) << r << '\n';
}

void input()
{
    std::cin >> n;
    for (int i = 1 ; i <= n ; ++i)
    {
        std::cin >> a[i];
    }
}

void fastIOI()
{
    std::ios_base :: sync_with_stdio(0);
    std::cout.tie(nullptr);
    std::cin.tie(nullptr);
}

int main()
{
    fastIOI();
    input();
    solve();

    return 0;
}
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 348 KB Output is correct
2 Incorrect 1 ms 348 KB Output isn't correct
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 348 KB Output is correct
2 Incorrect 1 ms 348 KB Output isn't correct
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 348 KB Output is correct
2 Incorrect 1 ms 348 KB Output isn't correct
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 0 ms 348 KB Output is correct
2 Incorrect 1 ms 348 KB Output isn't correct
3 Halted 0 ms 0 KB -