답안 #1020676

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
1020676 2024-07-12T08:21:21 Z vjudge1 Shortcut (IOI16_shortcut) C++17
0 / 100
2 ms 18880 KB
// #pragma once
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;

const ll INF = 1e18 + 100;
const int maxn = 1e6 + 100;
const int maxl = 20;

int n, C;
ll a[maxn];
ll b[maxn];
ll p[2][maxl][maxn];
int lg[maxn];
ll ans[3030][3030];
// struct asd{
// 	ll ans;
// 	ll a, b;
// } d[maxn * 4];

// asd f(asd a, asd b){
// 	asd c;
// 	c.a = max(a.a, b.a);
// 	c.b = max(a.b, b.b);
// 	c.ans = max({a.ans, b.ans, a.a + b.b});
// 	return c;
// }

// void build(int v = 1, int tl = 1, int tr = n){
// 	if(tl == tr){
// 		d[v] = {0, b[tl] - a[tl], b[tl] + a[tl]};
// 	} else{
// 		int mid = (tl + tr) >> 1;
// 		build(v<<1, tl, mid);
// 		build(v<<1|1, mid+1, tr);
// 		d[v] = f(d[v<<1], d[v<<1|1]);
// 	}
// }

// asd ans(int l, int r, int v = 1, int tl = 1, int tr = n){
// 	if(tr < l || tl > r) return {0, -INF, -INF};
// 	if(l <= tl && tr <= r) return d[v];
// 	int mid = (tl + tr) >> 1;
// 	return f(ans(l, r, v<<1, tl, mid)
// 	, ans(l, r, v<<1|1, mid+1, tr));
// }

ll get(int l, int r, int c){
	if(l > r) return -INF;
	int k = lg[r - l + 1];
	return max(p[c][k][l], p[c][k][r-(1<<k)+1]);
}

bool ok(ll x){
	int tl = 0, tr = n + 1;
	while(tl < n && ans[1][tl+1] <= x) tl++;
	while(tr > 1 && ans[tr-1][n] <= x) tr--;
	for(int l = 1; l <= tl; l++){
		for(int r = max(l + 1, tr); r <= n; r++){
			if(ans[l+1][r-1] > x) continue;
			if(get(1, l, 0) + a[l] + get(r, n, 1) - a[r] + C > x) continue;
			// if(get(tl+1, r-1, 0) + a[r] + C + get(1, l, 0) + a[l] > x) continue;
			// if(get(l+1, tr-1, 1) - a[l] + C + get(r, n, 1) - a[r] > x) continue;
			bool ok = 1;
			for(int m = l + 1; m < r; m++){
				if(b[m] + min(a[r] - a[m], a[m] - a[l] + C) + get(r, n, 1) - a[r] > x) ok = 0;
				if(b[m] + min(a[m] - a[l], a[r] - a[m] + C) + get(1, l, 0) + a[l] > x) ok = 0;
			}
			if(!ok) continue;
			return 1;
		}
	}
	return 0;
}

long long find_shortcut(int N, std::vector <int> l, std::vector <int> d, int c){
	n = N; C = c;
	for(int i = 1; i <= n; i++){
		b[i] = d[i-1];
		if(i == 1) continue;
		a[i] = a[i-1] + l[i - 2];
	}
	for(int i = 1; i <= n; i++){
		p[0][0][i] = b[i] - a[i];
		p[1][0][i] = b[i] + a[i];
		if(i > 1) lg[i] = lg[i >> 1] + 1;
	}
	for(int c = 0; c < 2; c++){
		for(int k = 1; k <= lg[n]; k++){
			for(int i = 1; i + (1<<k) - 1 <= n; i++){
				p[c][k][i] = max(p[c][k-1][i], p[c][k-1][i+(1<<(k-1))]);
			}
		}
	}
	for(int l = n - 1; l > 0; l--){
		for(int r = l + 1; r <= n; r++){
			ans[l][r] = max(ans[l][r-1],
				b[r] + a[r] + get(l, r-1, 0));
		}
	}
	ll res = ans[1][n];
	for(ll l = 0, r = res - 1; l <= r;){
		ll mid = (l + r) >> 1;
		if(!ok(mid)) l = mid + 1;
		else r = mid - 1, res = mid;
	}
	return res;
}
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 14680 KB n = 4, 80 is a correct answer
2 Correct 2 ms 16728 KB n = 9, 110 is a correct answer
3 Correct 1 ms 14684 KB n = 4, 21 is a correct answer
4 Correct 1 ms 10588 KB n = 3, 4 is a correct answer
5 Correct 1 ms 10588 KB n = 2, 62 is a correct answer
6 Correct 1 ms 10684 KB n = 2, 3 is a correct answer
7 Correct 2 ms 10588 KB n = 3, 29 is a correct answer
8 Correct 1 ms 10584 KB n = 2, 3 is a correct answer
9 Correct 1 ms 10588 KB n = 2, 3 is a correct answer
10 Correct 1 ms 10588 KB n = 2, 2000000001 is a correct answer
11 Correct 1 ms 10584 KB n = 2, 3000000000 is a correct answer
12 Correct 1 ms 10588 KB n = 3, 3000000000 is a correct answer
13 Correct 1 ms 10588 KB n = 3, 3000000000 is a correct answer
14 Correct 2 ms 14684 KB n = 4, 3000000001 is a correct answer
15 Correct 2 ms 14684 KB n = 4, 4000000000 is a correct answer
16 Correct 2 ms 14684 KB n = 5, 4000000000 is a correct answer
17 Correct 2 ms 18780 KB n = 10, 1000000343 is a correct answer
18 Correct 2 ms 18780 KB n = 10, 3189 is a correct answer
19 Correct 2 ms 18780 KB n = 10, 7000000000 is a correct answer
20 Correct 2 ms 14680 KB n = 5, 12 is a correct answer
21 Correct 2 ms 14680 KB n = 5, 25 is a correct answer
22 Correct 1 ms 10588 KB n = 2, 122 is a correct answer
23 Correct 2 ms 18780 KB n = 10, 117 is a correct answer
24 Correct 2 ms 18880 KB n = 10, 336 is a correct answer
25 Correct 2 ms 18780 KB n = 10, 438 is a correct answer
26 Incorrect 2 ms 18780 KB n = 10, incorrect answer: jury 206 vs contestant 217
27 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 14680 KB n = 4, 80 is a correct answer
2 Correct 2 ms 16728 KB n = 9, 110 is a correct answer
3 Correct 1 ms 14684 KB n = 4, 21 is a correct answer
4 Correct 1 ms 10588 KB n = 3, 4 is a correct answer
5 Correct 1 ms 10588 KB n = 2, 62 is a correct answer
6 Correct 1 ms 10684 KB n = 2, 3 is a correct answer
7 Correct 2 ms 10588 KB n = 3, 29 is a correct answer
8 Correct 1 ms 10584 KB n = 2, 3 is a correct answer
9 Correct 1 ms 10588 KB n = 2, 3 is a correct answer
10 Correct 1 ms 10588 KB n = 2, 2000000001 is a correct answer
11 Correct 1 ms 10584 KB n = 2, 3000000000 is a correct answer
12 Correct 1 ms 10588 KB n = 3, 3000000000 is a correct answer
13 Correct 1 ms 10588 KB n = 3, 3000000000 is a correct answer
14 Correct 2 ms 14684 KB n = 4, 3000000001 is a correct answer
15 Correct 2 ms 14684 KB n = 4, 4000000000 is a correct answer
16 Correct 2 ms 14684 KB n = 5, 4000000000 is a correct answer
17 Correct 2 ms 18780 KB n = 10, 1000000343 is a correct answer
18 Correct 2 ms 18780 KB n = 10, 3189 is a correct answer
19 Correct 2 ms 18780 KB n = 10, 7000000000 is a correct answer
20 Correct 2 ms 14680 KB n = 5, 12 is a correct answer
21 Correct 2 ms 14680 KB n = 5, 25 is a correct answer
22 Correct 1 ms 10588 KB n = 2, 122 is a correct answer
23 Correct 2 ms 18780 KB n = 10, 117 is a correct answer
24 Correct 2 ms 18880 KB n = 10, 336 is a correct answer
25 Correct 2 ms 18780 KB n = 10, 438 is a correct answer
26 Incorrect 2 ms 18780 KB n = 10, incorrect answer: jury 206 vs contestant 217
27 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 14680 KB n = 4, 80 is a correct answer
2 Correct 2 ms 16728 KB n = 9, 110 is a correct answer
3 Correct 1 ms 14684 KB n = 4, 21 is a correct answer
4 Correct 1 ms 10588 KB n = 3, 4 is a correct answer
5 Correct 1 ms 10588 KB n = 2, 62 is a correct answer
6 Correct 1 ms 10684 KB n = 2, 3 is a correct answer
7 Correct 2 ms 10588 KB n = 3, 29 is a correct answer
8 Correct 1 ms 10584 KB n = 2, 3 is a correct answer
9 Correct 1 ms 10588 KB n = 2, 3 is a correct answer
10 Correct 1 ms 10588 KB n = 2, 2000000001 is a correct answer
11 Correct 1 ms 10584 KB n = 2, 3000000000 is a correct answer
12 Correct 1 ms 10588 KB n = 3, 3000000000 is a correct answer
13 Correct 1 ms 10588 KB n = 3, 3000000000 is a correct answer
14 Correct 2 ms 14684 KB n = 4, 3000000001 is a correct answer
15 Correct 2 ms 14684 KB n = 4, 4000000000 is a correct answer
16 Correct 2 ms 14684 KB n = 5, 4000000000 is a correct answer
17 Correct 2 ms 18780 KB n = 10, 1000000343 is a correct answer
18 Correct 2 ms 18780 KB n = 10, 3189 is a correct answer
19 Correct 2 ms 18780 KB n = 10, 7000000000 is a correct answer
20 Correct 2 ms 14680 KB n = 5, 12 is a correct answer
21 Correct 2 ms 14680 KB n = 5, 25 is a correct answer
22 Correct 1 ms 10588 KB n = 2, 122 is a correct answer
23 Correct 2 ms 18780 KB n = 10, 117 is a correct answer
24 Correct 2 ms 18880 KB n = 10, 336 is a correct answer
25 Correct 2 ms 18780 KB n = 10, 438 is a correct answer
26 Incorrect 2 ms 18780 KB n = 10, incorrect answer: jury 206 vs contestant 217
27 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 14680 KB n = 4, 80 is a correct answer
2 Correct 2 ms 16728 KB n = 9, 110 is a correct answer
3 Correct 1 ms 14684 KB n = 4, 21 is a correct answer
4 Correct 1 ms 10588 KB n = 3, 4 is a correct answer
5 Correct 1 ms 10588 KB n = 2, 62 is a correct answer
6 Correct 1 ms 10684 KB n = 2, 3 is a correct answer
7 Correct 2 ms 10588 KB n = 3, 29 is a correct answer
8 Correct 1 ms 10584 KB n = 2, 3 is a correct answer
9 Correct 1 ms 10588 KB n = 2, 3 is a correct answer
10 Correct 1 ms 10588 KB n = 2, 2000000001 is a correct answer
11 Correct 1 ms 10584 KB n = 2, 3000000000 is a correct answer
12 Correct 1 ms 10588 KB n = 3, 3000000000 is a correct answer
13 Correct 1 ms 10588 KB n = 3, 3000000000 is a correct answer
14 Correct 2 ms 14684 KB n = 4, 3000000001 is a correct answer
15 Correct 2 ms 14684 KB n = 4, 4000000000 is a correct answer
16 Correct 2 ms 14684 KB n = 5, 4000000000 is a correct answer
17 Correct 2 ms 18780 KB n = 10, 1000000343 is a correct answer
18 Correct 2 ms 18780 KB n = 10, 3189 is a correct answer
19 Correct 2 ms 18780 KB n = 10, 7000000000 is a correct answer
20 Correct 2 ms 14680 KB n = 5, 12 is a correct answer
21 Correct 2 ms 14680 KB n = 5, 25 is a correct answer
22 Correct 1 ms 10588 KB n = 2, 122 is a correct answer
23 Correct 2 ms 18780 KB n = 10, 117 is a correct answer
24 Correct 2 ms 18880 KB n = 10, 336 is a correct answer
25 Correct 2 ms 18780 KB n = 10, 438 is a correct answer
26 Incorrect 2 ms 18780 KB n = 10, incorrect answer: jury 206 vs contestant 217
27 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 14680 KB n = 4, 80 is a correct answer
2 Correct 2 ms 16728 KB n = 9, 110 is a correct answer
3 Correct 1 ms 14684 KB n = 4, 21 is a correct answer
4 Correct 1 ms 10588 KB n = 3, 4 is a correct answer
5 Correct 1 ms 10588 KB n = 2, 62 is a correct answer
6 Correct 1 ms 10684 KB n = 2, 3 is a correct answer
7 Correct 2 ms 10588 KB n = 3, 29 is a correct answer
8 Correct 1 ms 10584 KB n = 2, 3 is a correct answer
9 Correct 1 ms 10588 KB n = 2, 3 is a correct answer
10 Correct 1 ms 10588 KB n = 2, 2000000001 is a correct answer
11 Correct 1 ms 10584 KB n = 2, 3000000000 is a correct answer
12 Correct 1 ms 10588 KB n = 3, 3000000000 is a correct answer
13 Correct 1 ms 10588 KB n = 3, 3000000000 is a correct answer
14 Correct 2 ms 14684 KB n = 4, 3000000001 is a correct answer
15 Correct 2 ms 14684 KB n = 4, 4000000000 is a correct answer
16 Correct 2 ms 14684 KB n = 5, 4000000000 is a correct answer
17 Correct 2 ms 18780 KB n = 10, 1000000343 is a correct answer
18 Correct 2 ms 18780 KB n = 10, 3189 is a correct answer
19 Correct 2 ms 18780 KB n = 10, 7000000000 is a correct answer
20 Correct 2 ms 14680 KB n = 5, 12 is a correct answer
21 Correct 2 ms 14680 KB n = 5, 25 is a correct answer
22 Correct 1 ms 10588 KB n = 2, 122 is a correct answer
23 Correct 2 ms 18780 KB n = 10, 117 is a correct answer
24 Correct 2 ms 18880 KB n = 10, 336 is a correct answer
25 Correct 2 ms 18780 KB n = 10, 438 is a correct answer
26 Incorrect 2 ms 18780 KB n = 10, incorrect answer: jury 206 vs contestant 217
27 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 14680 KB n = 4, 80 is a correct answer
2 Correct 2 ms 16728 KB n = 9, 110 is a correct answer
3 Correct 1 ms 14684 KB n = 4, 21 is a correct answer
4 Correct 1 ms 10588 KB n = 3, 4 is a correct answer
5 Correct 1 ms 10588 KB n = 2, 62 is a correct answer
6 Correct 1 ms 10684 KB n = 2, 3 is a correct answer
7 Correct 2 ms 10588 KB n = 3, 29 is a correct answer
8 Correct 1 ms 10584 KB n = 2, 3 is a correct answer
9 Correct 1 ms 10588 KB n = 2, 3 is a correct answer
10 Correct 1 ms 10588 KB n = 2, 2000000001 is a correct answer
11 Correct 1 ms 10584 KB n = 2, 3000000000 is a correct answer
12 Correct 1 ms 10588 KB n = 3, 3000000000 is a correct answer
13 Correct 1 ms 10588 KB n = 3, 3000000000 is a correct answer
14 Correct 2 ms 14684 KB n = 4, 3000000001 is a correct answer
15 Correct 2 ms 14684 KB n = 4, 4000000000 is a correct answer
16 Correct 2 ms 14684 KB n = 5, 4000000000 is a correct answer
17 Correct 2 ms 18780 KB n = 10, 1000000343 is a correct answer
18 Correct 2 ms 18780 KB n = 10, 3189 is a correct answer
19 Correct 2 ms 18780 KB n = 10, 7000000000 is a correct answer
20 Correct 2 ms 14680 KB n = 5, 12 is a correct answer
21 Correct 2 ms 14680 KB n = 5, 25 is a correct answer
22 Correct 1 ms 10588 KB n = 2, 122 is a correct answer
23 Correct 2 ms 18780 KB n = 10, 117 is a correct answer
24 Correct 2 ms 18880 KB n = 10, 336 is a correct answer
25 Correct 2 ms 18780 KB n = 10, 438 is a correct answer
26 Incorrect 2 ms 18780 KB n = 10, incorrect answer: jury 206 vs contestant 217
27 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 14680 KB n = 4, 80 is a correct answer
2 Correct 2 ms 16728 KB n = 9, 110 is a correct answer
3 Correct 1 ms 14684 KB n = 4, 21 is a correct answer
4 Correct 1 ms 10588 KB n = 3, 4 is a correct answer
5 Correct 1 ms 10588 KB n = 2, 62 is a correct answer
6 Correct 1 ms 10684 KB n = 2, 3 is a correct answer
7 Correct 2 ms 10588 KB n = 3, 29 is a correct answer
8 Correct 1 ms 10584 KB n = 2, 3 is a correct answer
9 Correct 1 ms 10588 KB n = 2, 3 is a correct answer
10 Correct 1 ms 10588 KB n = 2, 2000000001 is a correct answer
11 Correct 1 ms 10584 KB n = 2, 3000000000 is a correct answer
12 Correct 1 ms 10588 KB n = 3, 3000000000 is a correct answer
13 Correct 1 ms 10588 KB n = 3, 3000000000 is a correct answer
14 Correct 2 ms 14684 KB n = 4, 3000000001 is a correct answer
15 Correct 2 ms 14684 KB n = 4, 4000000000 is a correct answer
16 Correct 2 ms 14684 KB n = 5, 4000000000 is a correct answer
17 Correct 2 ms 18780 KB n = 10, 1000000343 is a correct answer
18 Correct 2 ms 18780 KB n = 10, 3189 is a correct answer
19 Correct 2 ms 18780 KB n = 10, 7000000000 is a correct answer
20 Correct 2 ms 14680 KB n = 5, 12 is a correct answer
21 Correct 2 ms 14680 KB n = 5, 25 is a correct answer
22 Correct 1 ms 10588 KB n = 2, 122 is a correct answer
23 Correct 2 ms 18780 KB n = 10, 117 is a correct answer
24 Correct 2 ms 18880 KB n = 10, 336 is a correct answer
25 Correct 2 ms 18780 KB n = 10, 438 is a correct answer
26 Incorrect 2 ms 18780 KB n = 10, incorrect answer: jury 206 vs contestant 217
27 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 2 ms 14680 KB n = 4, 80 is a correct answer
2 Correct 2 ms 16728 KB n = 9, 110 is a correct answer
3 Correct 1 ms 14684 KB n = 4, 21 is a correct answer
4 Correct 1 ms 10588 KB n = 3, 4 is a correct answer
5 Correct 1 ms 10588 KB n = 2, 62 is a correct answer
6 Correct 1 ms 10684 KB n = 2, 3 is a correct answer
7 Correct 2 ms 10588 KB n = 3, 29 is a correct answer
8 Correct 1 ms 10584 KB n = 2, 3 is a correct answer
9 Correct 1 ms 10588 KB n = 2, 3 is a correct answer
10 Correct 1 ms 10588 KB n = 2, 2000000001 is a correct answer
11 Correct 1 ms 10584 KB n = 2, 3000000000 is a correct answer
12 Correct 1 ms 10588 KB n = 3, 3000000000 is a correct answer
13 Correct 1 ms 10588 KB n = 3, 3000000000 is a correct answer
14 Correct 2 ms 14684 KB n = 4, 3000000001 is a correct answer
15 Correct 2 ms 14684 KB n = 4, 4000000000 is a correct answer
16 Correct 2 ms 14684 KB n = 5, 4000000000 is a correct answer
17 Correct 2 ms 18780 KB n = 10, 1000000343 is a correct answer
18 Correct 2 ms 18780 KB n = 10, 3189 is a correct answer
19 Correct 2 ms 18780 KB n = 10, 7000000000 is a correct answer
20 Correct 2 ms 14680 KB n = 5, 12 is a correct answer
21 Correct 2 ms 14680 KB n = 5, 25 is a correct answer
22 Correct 1 ms 10588 KB n = 2, 122 is a correct answer
23 Correct 2 ms 18780 KB n = 10, 117 is a correct answer
24 Correct 2 ms 18880 KB n = 10, 336 is a correct answer
25 Correct 2 ms 18780 KB n = 10, 438 is a correct answer
26 Incorrect 2 ms 18780 KB n = 10, incorrect answer: jury 206 vs contestant 217
27 Halted 0 ms 0 KB -