Submission #485445

#TimeUsernameProblemLanguageResultExecution timeMemory
485445EyedWall (IOI14_wall)C++14
100 / 100
979 ms100548 KiB
#include <algorithm>
#include <iostream>
#include <iomanip>
#include <fstream>
#include <string>
#include <vector>
#include <queue>
#include <stack>
#include <map>
#include <set>
#include <unordered_map>
#include <unordered_set>
#include <climits>
#include <cmath>
using namespace std;
typedef long long ll;
typedef pair<int, int> pii;
const ll MOD = 1e9 + 7;

struct range {
	int l;
	int r;
	range(int xx = 0, int yy = 0) : l(xx), r(yy) {};
};

int nn, kk;
int tree[8000055];
range lazy[8000055];
bool mark[8000055];

void app(int i, int j) {
	lazy[i].l = max(lazy[i].l, lazy[j].l);
	lazy[i].r = max(lazy[i].r, lazy[j].l);
	lazy[i].l = min(lazy[i].l, lazy[j].r);
	lazy[i].r = min(lazy[i].r, lazy[j].r);
}

void push(int v) {
		app(2 * v, v);
		app(2 * v + 1, v);
		lazy[v].l = 0;
		lazy[v].r = 100005;
		mark[v] = false;

}

void update(int v, int tl, int tr, int ll, int rr, int op, int x) {
	if (ll > rr) return;
	if (ll <= tl && rr >= tr) {
		if (op == 0) {
			lazy[v].l = max(lazy[v].l, x);
			lazy[v].r = max(lazy[v].r, lazy[v].l);
		}
		if (op == 1) {
			lazy[v].r = min(lazy[v].r, x);
			lazy[v].l = min(lazy[v].l, lazy[v].r);
		}
		mark[v] = true;
		return;
	}
	push(v);
	int pos = (tl + tr) / 2;
	update(2 * v, tl, pos, ll, min(pos, rr), op, x);
	update(2 * v + 1, pos + 1, tr, max(pos + 1, ll), rr, op, x);
}

int get(int v, int tl, int tr, int x) {
	if (tl == tr) {
	//	cout << lazy[v].l << " " << lazy[v].r << "; ";
		return lazy[v].l;
	}
	push(v);
	int tm = (tl + tr) / 2;
	if (x <= tm) return get(2 * v, tl, tm, x);
	else return get(2 * v + 1, tm + 1, tr, x);
}
void update(int ll, int rr, int op, int x) { update(1, 0, nn+1, ll, rr, op, x); }
int get(int x) { return get(1, 0, nn+1, x); }

void buildWall(int n, int k, int op[], int left[], int right[],
	int height[], int finalHeight[]) {
	nn = n;
	kk = k;
	for (int i = 0; i < n; ++i) tree[i] = 0;
	for (int i = 0; i < 8000055; ++i) {
		lazy[i].l = 0;
		lazy[i].r = 100005;
	}
	for (int i = 0; i < k; ++i) update(left[i], right[i], op[i] - 1, height[i]);
	for (int i = 0; i < n; ++i) finalHeight[i] = get(i);
	return;
}
//
//int main(int argc, char* argv[]) {
//	/*const char* FIN  = "sample.in";
//	const char* FOUT = "sample.out";
//	const char* inFile = argc > 1 ? argv[1] : FIN;
//	ifstream cin(inFile);
//	ofstream cout(FOUT);*/
//
//	cin >> nn >> kk;
//	for (int i = 0; i < nn; ++i) cin >> tree[i];
//	for (int i = 0; i < 8000005; ++i) {
//		lazy[i].l = 0;
//		lazy[i].r = 100005;
//	}
//	for (int i = 0; i < kk; ++i) {
//		int o, ll, rr, x;
//		cin >> o >> ll >> rr >> x;
//		update(ll, rr, o, x);
//		for (int i = 0; i < nn; ++i) cout << get(i) << " ";
//		
//		cout << endl; 
//		//o == 0 means adding, o == 1 means removing
//	}
//	for (int i = 0; i < nn; ++i) cout << get(i) << endl;
//
//
//	return 0;
//}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...