Submission #937814

# Submission time Handle Problem Language Result Execution time Memory
937814 2024-03-04T14:18:11 Z danikoynov Teams (IOI15_teams) C++14
21 / 100
4000 ms 10832 KB
#include "teams.h"
#include <bits/stdc++.h>
using namespace std;
const int maxn = 5e5 + 10;

struct segment
{
    int l, r;

    segment(int _l = 0, int _r = 0)
    {
        l = _l;
        r = _r;
    }
};

int n;
segment s[maxn];
void init(int N, int A[], int B[])
{
    n = N;
    for (int i = 1; i <= n; i ++)
        s[i] = segment(A[i - 1], B[i - 1]);
}

struct event
{
    int x, t, id;

    event(int _x = 0, int _t = 0, int _id = 0)
    {
        x = _x;
        t = _t;
        id = _id;
    }

};

bool cmp_event(event e1, event e2)
{
    if (e1.x != e2.x)
        return e1.x < e2.x;
    return e1.t < e2.t;
}

int dp[maxn];


int zeta(int j, int k)
{
    int cnt = 0;
    for (int i = 1; i <= n; i ++)
    {
        if (s[i].l <= j && s[i].r >= j)
            continue;
        if (s[i].l <= k && s[i].r >= k)
            cnt ++;
    }
    return cnt;
}
int can(int M, int K[])
{

    for (int i = 0; i < M; i ++)
    {
        dp[i] = 0;
    }

    sort(K, K + M);
    for (int i = 0; i < M; i ++)
    {

    for (int j = 1; j <= n; j ++)
        if (s[j].l <= K[i] && s[j].r >= K[i])
        dp[i] ++;
    dp[i] -= K[i];

    for (int j = 0; j < i; j ++)
    {
        dp[i] = min(dp[i], dp[j] + zeta(K[j], K[i]) - K[i]);
    }
    if (dp[i] < 0)
        return 0;
    }

    return 1;


    /**vector < event > events;
    for (int i = 0; i < M; i ++)
    {
        events.push_back(event(K[i], 0, -1));
    }
    for (int i = 1; i <= n; i ++)
    {
        events.push_back(event(s[i].l, -1, i));
        events.push_back(event(s[i].r, 1, i));
    }

    sort(events.begin(), events.end(), cmp_event);

    set < pair < int, int > > act;
    for (event cur : events)
    {
        if (cur.t == -1)
        {
            act.insert({s[cur.id].r, cur.id});
        }
        else
        if (cur.t == 1)
        {
            if (act.find({s[cur.id].r, cur.id}) != act.end())
                act.erase({s[cur.id].r, cur.id});
        }
        else
        {
            if (act.size() < cur.x)
            {
                return 0;
            }
            for (int d = 0; d < cur.x; d ++)
                act.erase(act.begin());
        }
    }
    return 1;*/
}
# Verdict Execution time Memory Grader output
1 Correct 2 ms 5980 KB Output is correct
2 Correct 1 ms 5980 KB Output is correct
3 Correct 2 ms 5980 KB Output is correct
4 Correct 2 ms 5980 KB Output is correct
5 Correct 2 ms 5980 KB Output is correct
6 Correct 2 ms 5980 KB Output is correct
7 Correct 4 ms 5980 KB Output is correct
8 Correct 2 ms 5980 KB Output is correct
9 Correct 2 ms 5980 KB Output is correct
10 Correct 3 ms 5980 KB Output is correct
11 Correct 2 ms 5980 KB Output is correct
12 Correct 12 ms 5980 KB Output is correct
13 Correct 4 ms 5980 KB Output is correct
14 Correct 3 ms 5980 KB Output is correct
15 Correct 2 ms 5980 KB Output is correct
16 Correct 2 ms 5980 KB Output is correct
17 Correct 2 ms 5980 KB Output is correct
18 Correct 2 ms 5976 KB Output is correct
19 Correct 2 ms 5980 KB Output is correct
20 Correct 2 ms 5980 KB Output is correct
21 Correct 2 ms 5980 KB Output is correct
22 Correct 2 ms 5980 KB Output is correct
23 Correct 2 ms 5980 KB Output is correct
24 Correct 2 ms 5980 KB Output is correct
25 Correct 2 ms 6068 KB Output is correct
26 Correct 2 ms 5980 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 8 ms 6748 KB Output is correct
2 Correct 6 ms 6748 KB Output is correct
3 Correct 6 ms 6748 KB Output is correct
4 Correct 9 ms 7456 KB Output is correct
5 Execution timed out 4046 ms 6748 KB Time limit exceeded
6 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 114 ms 7252 KB Output is correct
2 Correct 183 ms 7256 KB Output is correct
3 Execution timed out 4045 ms 7392 KB Time limit exceeded
4 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 844 ms 10832 KB Output is correct
2 Correct 817 ms 10824 KB Output is correct
3 Execution timed out 4101 ms 10348 KB Time limit exceeded
4 Halted 0 ms 0 KB -