Submission #1017880

#TimeUsernameProblemLanguageResultExecution timeMemory
1017880DorostWefTeams (IOI15_teams)C++17
0 / 100
1575 ms363996 KiB
#include "teams.h"
#include <bits/stdc++.h>

using namespace std;

typedef long long ll;
typedef pair <int, int> pii;
#define F first
#define S second
const int MXN = 500005, SegN = (1 << 20), LG = 19;
pii a[MXN];
int n;
vector <int> seg[SegN];
bool f[SegN];
int e[SegN], ans[SegN];
vector <int> vv;

int cnt (int v, int x) {
	if (seg[v].empty())
		return 0;
	return (upper_bound (seg[v].begin(), seg[v].end(), x)) - (upper_bound (seg[v].begin(), seg[v].end(), e[v])) - ans[v];
}

void shift (int v) {
	vv.push_back(v);
	vv.push_back(v * 2);
	vv.push_back(v * 2 + 1);
	if (e[v] > e[v * 2]) {
		e[v * 2] = e[v];
		ans[v * 2] = 0;
	}
	if (e[v] > e[v * 2 + 1]) {
		e[v * 2 + 1] = e[v];
		ans[v * 2 + 1] = 0;
	}
}

int find (int x) {
	int k = x;
	int v = (1 << 19) + (lower_bound (a, a + n, make_pair(x, 0)) - a);
	while (true) {
		while (v % 2 == 0)
			v /= 2;
		vector <int> wef;
		int few = v;
		while (few > 1) {
			few /= 2;
			wef.push_back(few);
		}
		reverse(wef.begin(), wef.end());
		for (int ff : wef)
			shift (ff);
		int w = cnt(v, x);
		if (w >= k) {
			break;
		} else {
			if (f[v]) {
				return MXN;
			}
			e[v] = x;
			ans[v] = 0;
			for (int ff : wef) {
				ans[ff] += w;
			}
			k -= w;
			v /= 2;
			++v;
		}
	}
	while (v < (1 << LG)) {
		shift (v);
		int w = (cnt (v * 2, x));
		vector <int> wef;
		int few = v;
		while (few) {
			wef.push_back(few);
			few /= 2;
		}
		if (w >= k) {
			v *= 2;
		} else {
			v *= 2;
			e[v] = x;
			for (int ff : wef)
				ans[ff] += w;
			v++;
			k -= w;
		}
	}
	vector <int> wef;
	int few = v;
	while (few > 1) {
		few /= 2;
		wef.push_back(few);
	}
	int w = 1;
	e[v] = x;
	for (int ff : wef)
		ans[ff] += w;
	return (v - (1 << LG));
}

void init(int N, int A[], int B[]) {
	for (int i = 0; i <= 20; i++) {
		f[(1 << i) - 1] = true;
	}
	n = N;
	for (int i = 0; i < n; i++) {
		a[i].F = B[i];
		a[i].S = A[i];
	}
	sort (a, a + n);
	for (int i = SegN - 1; i >= 0; i--) {
		if (i >= (1 << LG)) {
			if ((i - (1 << LG)) < n) {
				seg[i] = {a[i - (1 << LG)].S};
			}
		} else {
			merge (seg[i << 1].begin(), seg[i << 1].end(), seg[i << 1 | 1].begin(), seg[i << 1 | 1].end(), back_inserter(seg[i]));
		}
	}

}

int can(int M, int K[]) {
	vv.clear();
	sort (K, K + M);
	bool h = true;
	int st = 0;
	for (int i = 0; i < M; i++) {
		st = find (K[i]);
		if (st > n) 
			h = false;
		else if (a[st].F < K[i])
			h = false;
	}
	for (int v : vv) {
		e[v] = 0;
		ans[v] = 0;
	}
	return h;
}

Compilation message (stderr)

teams.cpp: In function 'int cnt(int, int)':
teams.cpp:21:110: warning: conversion from '__gnu_cxx::__normal_iterator<int*, std::vector<int> >::difference_type' {aka 'long int'} to 'int' may change value [-Wconversion]
   21 |  return (upper_bound (seg[v].begin(), seg[v].end(), x)) - (upper_bound (seg[v].begin(), seg[v].end(), e[v])) - ans[v];
      |         ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~
teams.cpp: In function 'int find(int)':
teams.cpp:40:20: warning: conversion from 'long int' to 'int' may change value [-Wconversion]
   40 |  int v = (1 << 19) + (lower_bound (a, a + n, make_pair(x, 0)) - a);
      |          ~~~~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...