This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "teams.h"
#include <algorithm>
#include <queue>
struct Node
{
Node(int d) : date(d) {}
Node(const Node &prev, int newDate)
{
value = prev.value;
date = newDate;
left = prev.left;
right = prev.right;
}
int value = 0, date;
int left = -1, right = -1;
};
class Interval
{
int left, right;
public:
Interval(int l, int r) : left(l), right(r) {}
bool IsIncludedIn(const Interval &other) const
{
return (other.left <= left && right <= other.right);
}
bool IsDisjointFrom(const Interval &other) const
{
return (other.right <= left || right <= other.left);
}
Interval Left() const
{
return Interval(left, (left + right) / 2);
}
Interval Right() const
{
return Interval((left + right) / 2, right);
}
};
const int MAXN = 5e5;
int students;
const int LEAVES = 1 << 19;
const Interval ROOTCOVER = { 0, LEAVES };
std::vector<int> interEnds[MAXN];
int root[MAXN];
std::vector<Node> tree;
void add(int node, Interval covered, Interval requested)
{
tree[node].value++;
if (!covered.IsIncludedIn(requested))
{
if (!covered.Left().IsDisjointFrom(requested))
{
if (tree[node].left == -1)
{
tree.emplace_back(tree[node].date);
tree[node].left = tree.size() - 1;
}
else if (tree[tree[node].left].date != tree[node].date)
{
tree.emplace_back(tree[tree[node].left], tree[node].date);
tree[node].left = tree.size() - 1;
}
add(tree[node].left, covered.Left(), requested);
}
if (!covered.Right().IsDisjointFrom(requested))
{
if (tree[node].right == -1)
{
tree.emplace_back(tree[node].date);
tree[node].right = tree.size() - 1;
}
else if (tree[tree[node].right].date != tree[node].date)
{
tree.emplace_back(tree[tree[node].right], tree[node].date);
tree[node].right = tree.size() - 1;
}
add(tree[node].right, covered.Right(), requested);
}
}
}
int count(int node, Interval covered, Interval requested)
{
if (node == -1 || covered.IsDisjointFrom(requested))
return 0;
if (covered.IsIncludedIn(requested))
return tree[node].value;
return (count(tree[node].left, covered.Left(), requested) + count(tree[node].right, covered.Right(), requested));
}
void init(int N, int A[], int B[])
{
students = N;
for (int iStud = 0; iStud < students; iStud++)
interEnds[A[iStud] - 1].emplace_back(B[iStud] - 1);
for (int iStart = 0; iStart < students; iStart++)
{
if (iStart == 0)
{
tree.emplace_back(0);
root[iStart] = 0;
}
else
{
tree.emplace_back(tree[root[iStart - 1]], iStart);
root[iStart] = tree.size() - 1;
}
for (int end : interEnds[iStart])
add(root[iStart], ROOTCOVER, Interval(end, end + 1));
}
}
int can(int M, int K[])
{
std::sort(K, K + M);
int used = 0, lastSeen = -1;
for (int iGroup = M - 1; iGroup > -1; iGroup--)
{
K[iGroup]--;
if (iGroup < M - 1)
used = std::max(0, used - lastSeen + count(root[K[iGroup]], ROOTCOVER, Interval(K[iGroup + 1], students)));
lastSeen = count(root[K[iGroup]], ROOTCOVER, Interval(K[iGroup], students));
if (lastSeen - used <= K[iGroup])
return 0;
used += K[iGroup] + 1;
}
return 1;
}
Compilation message (stderr)
teams.cpp: In function 'void add(int, Interval, Interval)':
teams.cpp:72:35: warning: conversion to 'int' from 'std::vector<Node>::size_type {aka long unsigned int}' may alter its value [-Wconversion]
tree[node].left = tree.size() - 1;
~~~~~~~~~~~~^~~
teams.cpp:77:35: warning: conversion to 'int' from 'std::vector<Node>::size_type {aka long unsigned int}' may alter its value [-Wconversion]
tree[node].left = tree.size() - 1;
~~~~~~~~~~~~^~~
teams.cpp:88:36: warning: conversion to 'int' from 'std::vector<Node>::size_type {aka long unsigned int}' may alter its value [-Wconversion]
tree[node].right = tree.size() - 1;
~~~~~~~~~~~~^~~
teams.cpp:93:36: warning: conversion to 'int' from 'std::vector<Node>::size_type {aka long unsigned int}' may alter its value [-Wconversion]
tree[node].right = tree.size() - 1;
~~~~~~~~~~~~^~~
teams.cpp: In function 'void init(int, int*, int*)':
teams.cpp:126:31: warning: conversion to 'int' from 'std::vector<Node>::size_type {aka long unsigned int}' may alter its value [-Wconversion]
root[iStart] = tree.size() - 1;
~~~~~~~~~~~~^~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |