답안 #96926

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
96926 2019-02-12T19:05:19 Z youngyojun Shortcut (IOI16_shortcut) C++11
0 / 100
3 ms 384 KB
#include "shortcut.h"
#include <bits/stdc++.h>
#define INFLL (0x3f3f3f3f3f3f3f3fll)
using namespace std;
typedef long long ll;
inline void upmin(ll &a, ll b) { if(b < a) a = b; }
inline void upmax(ll &a, ll b) { if(a < b) a = b; }

const int MAXN = 1000055;

ll X[MAXN], L[MAXN];
int O[MAXN], OJ[MAXN];

int N; ll K, Ans;

bool isp(ll Y) {
	ll xymx = -INFLL, xymn = INFLL, yxmx = -INFLL, yxmn = INFLL;
	ll mx = -INFLL, mn = INFLL;
	for(int oi = 0, i, oj = 0, j; oj < N; oj++) {
		j = OJ[oj];
		for(ll t = Y-X[j]-L[j]; oi < N; oi++) {
			i = O[oi];
			if(L[i]-X[i] <= t) break;
			upmax(mx, X[i]+L[i]);
			upmin(mn, X[i]-L[i]);
		}
		upmin(xymn, Y-K + mn + X[j]-L[j]);
		upmax(xymx, K-Y + mx + X[j]+L[j]);
		upmin(yxmn, Y-K - mx + X[j]-L[j]);
		upmax(yxmx, K-Y - mn + X[j]+L[j]);
	}
	for(int s = 0, xymxi = N-1, xymni = N-1, yxmxi = 0, yxmni = 0; s < N; s++) {
		for(ll t = xymx-X[s]; xymxi && t <= X[xymxi-1]; xymxi--);
		for(ll t = xymn-X[s]; 0 <= xymni && t < X[xymni]; xymni--);
		for(ll t = yxmx+X[s]; yxmxi < N && X[yxmxi] < t; yxmxi++);
		for(ll t = yxmn+X[s]; yxmni+1 < N && X[yxmni+1] <= t; yxmni++);
		if(X[xymxi] < xymx-X[s] || yxmn+X[s] < X[yxmni]) continue;
		if(max(xymxi, yxmxi) <= min(xymni, yxmni)) return true;
	}
	return false;
}

ll getAns() {
	ll mx = -INFLL;
	for(int i = 0; i < N; i++) {
		upmax(Ans, X[i]+L[i] + mx);
		upmax(mx, L[i]-X[i]);
	}
	iota(O, O+N, 0); sort(O, O+N, [&](int a, int b) {
		return L[a]-X[a] > L[b]-X[b];
	});
	iota(OJ, OJ+N, 0); sort(OJ, OJ+N, [&](int a, int b) {
		return X[a]+L[a] < X[b]+L[b];
	});
	ll a = 0, b = 0;
	for(int i = 0; i < N; i++) {
		ll c = L[i];
		if(a < c) swap(a, c);
		if(b < c) swap(b, c);
	}
	ll s = min(Ans, a+b+K), e = Ans;
	for(ll m; s < e;) {
		m = (s+e) >> 1;
		if(isp(m)) e = m;
		else s = m+1;
	}
	return s;
}

long long find_shortcut(int n, std::vector<int> l, std::vector<int> d, int c) {
	::N = n; ::K = c;
	for(int i = 1; i < N; i++) ::X[i] = ::X[i-1] + l[i-1];
	for(int i = 0; i < N; i++) ::L[i] = d[i];
    return getAns();
}
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 384 KB n = 4, 80 is a correct answer
2 Correct 2 ms 384 KB n = 9, 110 is a correct answer
3 Correct 3 ms 384 KB n = 4, 21 is a correct answer
4 Correct 2 ms 384 KB n = 3, 4 is a correct answer
5 Incorrect 3 ms 384 KB n = 2, incorrect answer: jury 62 vs contestant 71
6 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 384 KB n = 4, 80 is a correct answer
2 Correct 2 ms 384 KB n = 9, 110 is a correct answer
3 Correct 3 ms 384 KB n = 4, 21 is a correct answer
4 Correct 2 ms 384 KB n = 3, 4 is a correct answer
5 Incorrect 3 ms 384 KB n = 2, incorrect answer: jury 62 vs contestant 71
6 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 384 KB n = 4, 80 is a correct answer
2 Correct 2 ms 384 KB n = 9, 110 is a correct answer
3 Correct 3 ms 384 KB n = 4, 21 is a correct answer
4 Correct 2 ms 384 KB n = 3, 4 is a correct answer
5 Incorrect 3 ms 384 KB n = 2, incorrect answer: jury 62 vs contestant 71
6 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 384 KB n = 4, 80 is a correct answer
2 Correct 2 ms 384 KB n = 9, 110 is a correct answer
3 Correct 3 ms 384 KB n = 4, 21 is a correct answer
4 Correct 2 ms 384 KB n = 3, 4 is a correct answer
5 Incorrect 3 ms 384 KB n = 2, incorrect answer: jury 62 vs contestant 71
6 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 384 KB n = 4, 80 is a correct answer
2 Correct 2 ms 384 KB n = 9, 110 is a correct answer
3 Correct 3 ms 384 KB n = 4, 21 is a correct answer
4 Correct 2 ms 384 KB n = 3, 4 is a correct answer
5 Incorrect 3 ms 384 KB n = 2, incorrect answer: jury 62 vs contestant 71
6 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 384 KB n = 4, 80 is a correct answer
2 Correct 2 ms 384 KB n = 9, 110 is a correct answer
3 Correct 3 ms 384 KB n = 4, 21 is a correct answer
4 Correct 2 ms 384 KB n = 3, 4 is a correct answer
5 Incorrect 3 ms 384 KB n = 2, incorrect answer: jury 62 vs contestant 71
6 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 384 KB n = 4, 80 is a correct answer
2 Correct 2 ms 384 KB n = 9, 110 is a correct answer
3 Correct 3 ms 384 KB n = 4, 21 is a correct answer
4 Correct 2 ms 384 KB n = 3, 4 is a correct answer
5 Incorrect 3 ms 384 KB n = 2, incorrect answer: jury 62 vs contestant 71
6 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 384 KB n = 4, 80 is a correct answer
2 Correct 2 ms 384 KB n = 9, 110 is a correct answer
3 Correct 3 ms 384 KB n = 4, 21 is a correct answer
4 Correct 2 ms 384 KB n = 3, 4 is a correct answer
5 Incorrect 3 ms 384 KB n = 2, incorrect answer: jury 62 vs contestant 71
6 Halted 0 ms 0 KB -