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 <bits/stdc++.h>
using namespace std;
typedef long long ll;
#define debug(x) cerr << #x << ": " << x << endl;
#define all(x) (x).begin(), (x).end()
const int MAXN = 4e6 + 10;
struct node {
node *lc, *rc;
ll val;
node() {}
node(ll val_): lc(nullptr), rc(nullptr), val(val_) {}
node(node* lc_, node* rc_): lc(lc_), rc(rc_) {
val = lc_ -> val + rc_ -> val;
}
};
namespace segment {
node* sg[MAXN];
node* build(int l, int r) {
if (l == r) return new node(0);
int mid = (l + r) >> 1;
return new node(build(l, mid), build(mid + 1, r));
}
node* update(int ind, int l, int r, node* v) {
if (l == r) return new node((v -> val) + 1);
int mid = (l + r) >> 1;
if (ind <= mid) return new node(update(ind, l, mid, v -> lc), v -> rc);
else return new node(v -> lc, update(ind, mid + 1, r, v -> rc));
}
int query(int ql, int qr, int l, int r, node* v) {
if (ql > r || qr < l) return 0;
if (ql <= l && qr >= r) return v -> val;
int mid = (l + r) >> 1;
return query(ql, qr, l, mid, v -> lc) +
query(ql, qr, mid + 1, r, v -> rc);
}
}
int n, ps[MAXN];
vector<int> R[MAXN];
void init(int N, int A[], int B[]) {
n = N;
for (int i = 0; i < n; i++) {
R[B[i]].push_back(A[i]);
ps[A[i]]++;
}
for (int i = 1; i <= n; i++) ps[i] += ps[i - 1];
segment::sg[0] = segment::build(1, n);
for (int i = 1; i <= n; i++) {
node* v = segment::sg[i - 1];
for (int l : R[i])
v = segment::update(l, 1, n, v);
segment::sg[i] = v;
}
}
inline int get(int l, int r) {
if (r < l) return 0;
return segment::query(l, n, 1, n, segment::sg[r]);
}
inline int cov(int l, int r) {
ll s = ps[r] - ps[l - 1];
return s - get(l, r - 1);
}
int dp[MAXN], F[MAXN];
inline void clear(int M, int K[]) {
for (int i = 0; i < M; i++)
F[K[i]] = 0;
}
int can(int M, int K[]) {
int m = M, s = 0;
vector<int> vec;
for (int i = 0; i < m; i++) {
s += K[i];
if (s > n) {
clear(M, K);
return 0;
}
F[K[i]] += K[i];
vec.push_back(K[i]);
}
sort(all(vec));
vec.resize(unique(all(vec)) - vec.begin());
vec.insert(vec.begin(), 0);
dp[0] = 0;
m = vec.size();
for (int i = 1; i < m; i++) {
dp[i] = numeric_limits<int>::max();
for (int j = 0; j < i; j++)
dp[i] = min(dp[i], dp[j] + cov(vec[j] + 1, vec[i]) - F[vec[i]]);
if (dp[i] < 0) return 0;
}
return 1;
}
Compilation message (stderr)
teams.cpp: In function 'int segment::query(int, int, int, int, node*)':
teams.cpp:42:39: warning: conversion from 'll' {aka 'long long int'} to 'int' may change value [-Wconversion]
42 | if (ql <= l && qr >= r) return v -> val;
| ~~~~~^~~
teams.cpp: In function 'int cov(int, int)':
teams.cpp:79:11: warning: conversion from 'll' {aka 'long long int'} to 'int' may change value [-Wconversion]
79 | return s - get(l, r - 1);
| ~~^~~~~~~~~~~~~~~
teams.cpp: In function 'int can(int, int*)':
teams.cpp:110:14: warning: conversion from 'std::vector<int>::size_type' {aka 'long unsigned int'} to 'int' may change value [-Wconversion]
110 | m = vec.size();
| ~~~~~~~~^~
# | 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... |