Submission #412787

# Submission time Handle Problem Language Result Execution time Memory
412787 2021-05-27T13:46:55 Z b00n0rp Rainforest Jumps (APIO21_jumps) C++17
100 / 100
1866 ms 108980 KB
#include "jumps.h"

#include <bits/stdc++.h>
using namespace std;

typedef long double LD;
typedef long long ll;
// #define int ll
#define pb push_back
#define mp make_pair
#define REP(i,n) for (int i = 0; i < n; i++)
#define FOR(i,a,b) for (int i = a; i < b; i++)
#define REPD(i,n) for (int i = n-1; i >= 0; i--)
#define FORD(i,a,b) for (int i = a; i >= b; i--)
#define remax(a,b) a = max(a,b)
#define remin(a,b) a = min(a,b)
#define all(v) v.begin(),v.end()
typedef map<int,int> mii;
typedef vector<int> vi;
typedef vector<vi> vvi;
typedef pair<int,int> pii;
typedef vector<pii> vpii;
#define F first
#define S second
#define PQ(type) priority_queue<type>
#define PQD(type) priority_queue<type,vector<type>,greater<type> >
#define WL(t) while(t --)
#define SZ(x) ((int)(x).size())
#define runtime() ((double)clock() / CLOCKS_PER_SEC)
#define inrange(i,a,b) ((i>=min(a,b)) && (i<=max(a,b)))

#ifdef TRACE
#define trace(...) __f(#__VA_ARGS__, __VA_ARGS__)
template <typename Arg1>
void __f(const char* name, Arg1&& arg1){
    cout << name << " : " << arg1 << std::endl;
}
template <typename Arg1, typename... Args>
void __f(const char* names, Arg1&& arg1, Args&&... args){
    const char* comma = strchr(names + 1, ',');cout.write(names, comma - names) << " : " << arg1<<" | ";__f(comma+1, args...);
}
#else
#define trace(...)
#endif

const int MAXN = 200005;

int a[MAXN],ng[MAXN],pg[MAXN];
int dist[MAXN];

int lft[MAXN][22],rgt[MAXN][22];
int lftmax[MAXN][22],rgtmax[MAXN][22];

int n;

int segpg[2*MAXN];
vi segng[2*MAXN];

int querypg(int l,int r){
	l += n;
	r += n+1;
	int res = l;
	while(l < r){
		if(l%2) remin(res,segpg[l++]);
		if(r%2) remin(res,segpg[--r]);
		l /= 2;
		r /= 2;
	}
	return res;
}

int queryng(int l,int r,int x){
	// trace(l,r,x);
	int res = r;
	l += n;
	r += n+1;
	while(l < r){
		if(l%2){
			if(segng[l][0] <= x){
				auto it = lower_bound(all(segng[l]),x+1);
				it--;
				remax(res,(*it));
			}
			l++;
		}
		if(r%2){
			--r;
			if(segng[r][0] <= x){
				auto it = lower_bound(all(segng[r]),x+1);
				it--;
				remax(res,(*it));
			}
		}
		l /= 2;
		r /= 2;
	}
	// trace(res);
	return res;
}

void init(int N, vi H) {
	n = N;
	REP(i,n){
		a[i] = H[i];
	}
	stack<int> st;
	REP(i,n){
		while(SZ(st) and H[st.top()] < H[i]){
			ng[st.top()] = i;
			st.pop();
		}
		st.push(i);
	}
	while(!st.empty()){
		ng[st.top()] = st.top();
		st.pop();
	}
	FORD(i,n-1,0){
		while(SZ(st) and H[st.top()] < H[i]){
			pg[st.top()] = i;
			st.pop();
		}
		st.push(i);
	}
	while(!st.empty()){
		pg[st.top()] = st.top();
		st.pop();
	}
	REP(i,n){
		lft[i][0] = pg[i];
		lftmax[i][0] = pg[i];
		rgt[i][0] = ng[i];
		rgtmax[i][0] = ng[i];
		segpg[i+n] = pg[i];
		segng[i+n].pb(ng[i]);
	}
	FORD(i,n-1,1){
		segpg[i] = min(segpg[2*i],segpg[2*i+1]);
		for(auto x:segng[2*i]) segng[i].pb(x);
		for(auto x:segng[2*i+1]) segng[i].pb(x);
		sort(all(segng[i]));
	}
	// REP(i,2*n){
	// 	trace(i,SZ(segng[i]));
	// 	for(auto x:segng[i]) trace(x);
	// }
	FOR(j,1,20){
		REP(i,n){
			lft[i][j] = lft[lft[i][j-1]][j-1];
			rgt[i][j] = rgt[rgt[i][j-1]][j-1];
			lftmax[i][j] = min(lftmax[lftmax[i][j-1]][j-1],lftmax[rgtmax[i][j-1]][j-1]);
			rgtmax[i][j] = max(rgtmax[lftmax[i][j-1]][j-1],rgtmax[rgtmax[i][j-1]][j-1]);
		}
	}
}

int minimum_jumps(int A, int B, int C, int D) {
	int l = A,r = B;
	int cnt = 1;
	l = querypg(A,B);
	r = queryng(A,B,D);
	if(r >= C) return cnt;
	FORD(j,19,0){
		if(max(rgtmax[l][j],rgtmax[r][j]) < C){
			cnt += (1<<j);
			int newl = min(lftmax[l][j],lftmax[r][j]);
			int newr = max(rgtmax[l][j],rgtmax[r][j]);
			l = newl;
			r = newr;
		}
	}
	if(ng[l] >= C and ng[l] <= D) return cnt+1;
	FORD(j,19,0){
		if(rgt[r][j] < C){
			cnt += (1<<j);
			r = rgt[r][j];
		}
	}
	if(ng[r] >= C and ng[r] <= D) return cnt+1;
	return -1;
}
# Verdict Execution time Memory Grader output
1 Correct 6 ms 9672 KB Output is correct
2 Correct 6 ms 9672 KB Output is correct
3 Correct 376 ms 88772 KB Output is correct
4 Correct 1680 ms 108584 KB Output is correct
5 Correct 1385 ms 59196 KB Output is correct
6 Correct 1539 ms 108600 KB Output is correct
7 Correct 1162 ms 77648 KB Output is correct
8 Correct 1728 ms 108536 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 6 ms 9672 KB Output is correct
2 Correct 6 ms 9672 KB Output is correct
3 Correct 6 ms 9672 KB Output is correct
4 Correct 6 ms 9672 KB Output is correct
5 Correct 9 ms 9668 KB Output is correct
6 Correct 9 ms 9800 KB Output is correct
7 Correct 8 ms 9800 KB Output is correct
8 Correct 9 ms 9800 KB Output is correct
9 Correct 7 ms 9800 KB Output is correct
10 Correct 10 ms 9800 KB Output is correct
11 Correct 9 ms 9800 KB Output is correct
12 Correct 10 ms 9800 KB Output is correct
13 Correct 9 ms 9800 KB Output is correct
14 Correct 10 ms 9748 KB Output is correct
15 Correct 9 ms 9800 KB Output is correct
16 Correct 9 ms 9800 KB Output is correct
17 Correct 8 ms 9800 KB Output is correct
18 Correct 7 ms 9672 KB Output is correct
19 Correct 7 ms 9672 KB Output is correct
20 Correct 8 ms 9800 KB Output is correct
21 Correct 8 ms 9800 KB Output is correct
22 Correct 8 ms 9764 KB Output is correct
23 Correct 8 ms 9820 KB Output is correct
24 Correct 9 ms 9800 KB Output is correct
25 Correct 7 ms 9672 KB Output is correct
26 Correct 6 ms 9672 KB Output is correct
27 Correct 8 ms 9672 KB Output is correct
28 Correct 10 ms 9800 KB Output is correct
29 Correct 9 ms 9800 KB Output is correct
30 Correct 9 ms 9756 KB Output is correct
31 Correct 9 ms 9800 KB Output is correct
32 Correct 9 ms 9800 KB Output is correct
33 Correct 7 ms 9624 KB Output is correct
34 Correct 7 ms 9800 KB Output is correct
35 Correct 7 ms 9800 KB Output is correct
36 Correct 7 ms 9800 KB Output is correct
37 Correct 6 ms 9800 KB Output is correct
38 Correct 7 ms 9800 KB Output is correct
39 Correct 7 ms 9800 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 6 ms 9672 KB Output is correct
2 Correct 6 ms 9672 KB Output is correct
3 Correct 6 ms 9672 KB Output is correct
4 Correct 6 ms 9672 KB Output is correct
5 Correct 9 ms 9668 KB Output is correct
6 Correct 9 ms 9800 KB Output is correct
7 Correct 8 ms 9800 KB Output is correct
8 Correct 9 ms 9800 KB Output is correct
9 Correct 7 ms 9800 KB Output is correct
10 Correct 10 ms 9800 KB Output is correct
11 Correct 9 ms 9800 KB Output is correct
12 Correct 10 ms 9800 KB Output is correct
13 Correct 9 ms 9800 KB Output is correct
14 Correct 10 ms 9748 KB Output is correct
15 Correct 9 ms 9800 KB Output is correct
16 Correct 9 ms 9800 KB Output is correct
17 Correct 8 ms 9800 KB Output is correct
18 Correct 7 ms 9672 KB Output is correct
19 Correct 7 ms 9672 KB Output is correct
20 Correct 8 ms 9800 KB Output is correct
21 Correct 8 ms 9800 KB Output is correct
22 Correct 8 ms 9764 KB Output is correct
23 Correct 8 ms 9820 KB Output is correct
24 Correct 9 ms 9800 KB Output is correct
25 Correct 7 ms 9672 KB Output is correct
26 Correct 6 ms 9672 KB Output is correct
27 Correct 8 ms 9672 KB Output is correct
28 Correct 10 ms 9800 KB Output is correct
29 Correct 9 ms 9800 KB Output is correct
30 Correct 9 ms 9756 KB Output is correct
31 Correct 9 ms 9800 KB Output is correct
32 Correct 9 ms 9800 KB Output is correct
33 Correct 7 ms 9624 KB Output is correct
34 Correct 7 ms 9800 KB Output is correct
35 Correct 7 ms 9800 KB Output is correct
36 Correct 7 ms 9800 KB Output is correct
37 Correct 6 ms 9800 KB Output is correct
38 Correct 7 ms 9800 KB Output is correct
39 Correct 7 ms 9800 KB Output is correct
40 Correct 6 ms 9672 KB Output is correct
41 Correct 7 ms 9672 KB Output is correct
42 Correct 6 ms 9672 KB Output is correct
43 Correct 7 ms 9672 KB Output is correct
44 Correct 8 ms 9672 KB Output is correct
45 Correct 9 ms 9800 KB Output is correct
46 Correct 7 ms 9756 KB Output is correct
47 Correct 9 ms 9800 KB Output is correct
48 Correct 7 ms 9800 KB Output is correct
49 Correct 8 ms 9808 KB Output is correct
50 Correct 8 ms 9800 KB Output is correct
51 Correct 8 ms 9800 KB Output is correct
52 Correct 9 ms 9800 KB Output is correct
53 Correct 9 ms 9800 KB Output is correct
54 Correct 9 ms 9800 KB Output is correct
55 Correct 9 ms 9800 KB Output is correct
56 Correct 10 ms 9800 KB Output is correct
57 Correct 7 ms 9800 KB Output is correct
58 Correct 16 ms 10524 KB Output is correct
59 Correct 19 ms 10604 KB Output is correct
60 Correct 14 ms 10056 KB Output is correct
61 Correct 34 ms 10568 KB Output is correct
62 Correct 24 ms 9776 KB Output is correct
63 Correct 24 ms 10568 KB Output is correct
64 Correct 33 ms 10568 KB Output is correct
65 Correct 32 ms 10568 KB Output is correct
66 Correct 25 ms 10568 KB Output is correct
67 Correct 36 ms 10568 KB Output is correct
68 Correct 36 ms 10568 KB Output is correct
69 Correct 35 ms 10568 KB Output is correct
70 Correct 25 ms 10568 KB Output is correct
71 Correct 7 ms 9672 KB Output is correct
72 Correct 7 ms 9800 KB Output is correct
73 Correct 9 ms 9800 KB Output is correct
74 Correct 9 ms 9800 KB Output is correct
75 Correct 9 ms 9768 KB Output is correct
76 Correct 9 ms 9800 KB Output is correct
77 Correct 9 ms 9800 KB Output is correct
78 Correct 7 ms 9672 KB Output is correct
79 Correct 7 ms 9672 KB Output is correct
80 Correct 7 ms 9672 KB Output is correct
81 Correct 8 ms 9800 KB Output is correct
82 Correct 10 ms 9800 KB Output is correct
83 Correct 9 ms 9800 KB Output is correct
84 Correct 10 ms 9792 KB Output is correct
85 Correct 9 ms 9800 KB Output is correct
86 Correct 7 ms 9672 KB Output is correct
87 Correct 7 ms 9800 KB Output is correct
88 Correct 6 ms 9800 KB Output is correct
89 Correct 7 ms 9800 KB Output is correct
90 Correct 7 ms 9800 KB Output is correct
91 Correct 7 ms 9728 KB Output is correct
92 Correct 7 ms 9800 KB Output is correct
93 Correct 7 ms 9800 KB Output is correct
94 Correct 10 ms 9800 KB Output is correct
95 Correct 36 ms 10568 KB Output is correct
96 Correct 37 ms 10568 KB Output is correct
97 Correct 19 ms 10568 KB Output is correct
98 Correct 28 ms 10568 KB Output is correct
99 Correct 34 ms 10568 KB Output is correct
100 Correct 7 ms 9800 KB Output is correct
101 Correct 8 ms 10056 KB Output is correct
102 Correct 18 ms 10696 KB Output is correct
103 Correct 30 ms 10568 KB Output is correct
104 Correct 26 ms 10568 KB Output is correct
105 Correct 30 ms 10676 KB Output is correct
106 Correct 33 ms 10568 KB Output is correct
107 Correct 7 ms 9784 KB Output is correct
108 Correct 8 ms 10056 KB Output is correct
109 Correct 9 ms 10568 KB Output is correct
110 Correct 9 ms 10568 KB Output is correct
111 Correct 9 ms 10568 KB Output is correct
112 Correct 9 ms 10696 KB Output is correct
113 Correct 9 ms 10568 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 7 ms 9672 KB Output is correct
2 Correct 6 ms 9672 KB Output is correct
3 Correct 7 ms 9672 KB Output is correct
4 Correct 6 ms 9672 KB Output is correct
5 Correct 239 ms 89528 KB Output is correct
6 Correct 307 ms 108440 KB Output is correct
7 Correct 165 ms 60076 KB Output is correct
8 Correct 299 ms 108664 KB Output is correct
9 Correct 50 ms 24344 KB Output is correct
10 Correct 321 ms 108456 KB Output is correct
11 Correct 287 ms 108680 KB Output is correct
12 Correct 284 ms 108564 KB Output is correct
13 Correct 280 ms 108856 KB Output is correct
14 Correct 301 ms 108548 KB Output is correct
15 Correct 320 ms 108844 KB Output is correct
16 Correct 280 ms 108980 KB Output is correct
17 Correct 292 ms 108868 KB Output is correct
18 Correct 7 ms 9704 KB Output is correct
19 Correct 7 ms 9800 KB Output is correct
20 Correct 7 ms 9800 KB Output is correct
21 Correct 7 ms 9800 KB Output is correct
22 Correct 7 ms 9800 KB Output is correct
23 Correct 7 ms 9744 KB Output is correct
24 Correct 7 ms 9800 KB Output is correct
25 Correct 7 ms 9800 KB Output is correct
26 Correct 7 ms 10056 KB Output is correct
27 Correct 9 ms 10568 KB Output is correct
28 Correct 9 ms 10568 KB Output is correct
29 Correct 9 ms 10696 KB Output is correct
30 Correct 8 ms 10676 KB Output is correct
31 Correct 8 ms 10568 KB Output is correct
32 Correct 7 ms 9672 KB Output is correct
33 Correct 307 ms 108352 KB Output is correct
34 Correct 294 ms 108520 KB Output is correct
35 Correct 288 ms 108536 KB Output is correct
36 Correct 291 ms 108668 KB Output is correct
37 Correct 311 ms 108932 KB Output is correct
38 Correct 283 ms 108532 KB Output is correct
39 Correct 6 ms 9672 KB Output is correct
40 Correct 175 ms 66652 KB Output is correct
41 Correct 314 ms 108568 KB Output is correct
42 Correct 281 ms 108560 KB Output is correct
43 Correct 307 ms 108492 KB Output is correct
44 Correct 316 ms 108888 KB Output is correct
45 Correct 269 ms 108676 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 7 ms 9672 KB Output is correct
2 Correct 7 ms 9672 KB Output is correct
3 Correct 8 ms 9672 KB Output is correct
4 Correct 432 ms 54720 KB Output is correct
5 Correct 1405 ms 108568 KB Output is correct
6 Correct 748 ms 25800 KB Output is correct
7 Correct 1362 ms 108556 KB Output is correct
8 Correct 605 ms 43620 KB Output is correct
9 Correct 1548 ms 108536 KB Output is correct
10 Correct 1334 ms 108536 KB Output is correct
11 Correct 1573 ms 108876 KB Output is correct
12 Correct 1252 ms 108608 KB Output is correct
13 Correct 1529 ms 108536 KB Output is correct
14 Correct 1590 ms 108816 KB Output is correct
15 Correct 962 ms 108540 KB Output is correct
16 Correct 1189 ms 108548 KB Output is correct
17 Correct 7 ms 9672 KB Output is correct
18 Correct 7 ms 9672 KB Output is correct
19 Correct 7 ms 9672 KB Output is correct
20 Correct 8 ms 9800 KB Output is correct
21 Correct 8 ms 9800 KB Output is correct
22 Correct 9 ms 9732 KB Output is correct
23 Correct 10 ms 9800 KB Output is correct
24 Correct 9 ms 9772 KB Output is correct
25 Correct 7 ms 9800 KB Output is correct
26 Correct 8 ms 10056 KB Output is correct
27 Correct 18 ms 10568 KB Output is correct
28 Correct 34 ms 10652 KB Output is correct
29 Correct 27 ms 10568 KB Output is correct
30 Correct 18 ms 10568 KB Output is correct
31 Correct 27 ms 10568 KB Output is correct
32 Correct 6 ms 9672 KB Output is correct
33 Correct 176 ms 66636 KB Output is correct
34 Correct 295 ms 108536 KB Output is correct
35 Correct 299 ms 108620 KB Output is correct
36 Correct 297 ms 108436 KB Output is correct
37 Correct 322 ms 108940 KB Output is correct
38 Correct 272 ms 108536 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 7 ms 9672 KB Output is correct
2 Correct 7 ms 9672 KB Output is correct
3 Correct 8 ms 9672 KB Output is correct
4 Correct 432 ms 54720 KB Output is correct
5 Correct 1405 ms 108568 KB Output is correct
6 Correct 748 ms 25800 KB Output is correct
7 Correct 1362 ms 108556 KB Output is correct
8 Correct 605 ms 43620 KB Output is correct
9 Correct 1548 ms 108536 KB Output is correct
10 Correct 1334 ms 108536 KB Output is correct
11 Correct 1573 ms 108876 KB Output is correct
12 Correct 1252 ms 108608 KB Output is correct
13 Correct 1529 ms 108536 KB Output is correct
14 Correct 1590 ms 108816 KB Output is correct
15 Correct 962 ms 108540 KB Output is correct
16 Correct 1189 ms 108548 KB Output is correct
17 Correct 7 ms 9672 KB Output is correct
18 Correct 7 ms 9672 KB Output is correct
19 Correct 7 ms 9672 KB Output is correct
20 Correct 8 ms 9800 KB Output is correct
21 Correct 8 ms 9800 KB Output is correct
22 Correct 9 ms 9732 KB Output is correct
23 Correct 10 ms 9800 KB Output is correct
24 Correct 9 ms 9772 KB Output is correct
25 Correct 7 ms 9800 KB Output is correct
26 Correct 8 ms 10056 KB Output is correct
27 Correct 18 ms 10568 KB Output is correct
28 Correct 34 ms 10652 KB Output is correct
29 Correct 27 ms 10568 KB Output is correct
30 Correct 18 ms 10568 KB Output is correct
31 Correct 27 ms 10568 KB Output is correct
32 Correct 6 ms 9672 KB Output is correct
33 Correct 176 ms 66636 KB Output is correct
34 Correct 295 ms 108536 KB Output is correct
35 Correct 299 ms 108620 KB Output is correct
36 Correct 297 ms 108436 KB Output is correct
37 Correct 322 ms 108940 KB Output is correct
38 Correct 272 ms 108536 KB Output is correct
39 Correct 7 ms 9672 KB Output is correct
40 Correct 7 ms 9672 KB Output is correct
41 Correct 7 ms 9672 KB Output is correct
42 Correct 417 ms 54712 KB Output is correct
43 Correct 1514 ms 108548 KB Output is correct
44 Correct 702 ms 25800 KB Output is correct
45 Correct 1372 ms 108572 KB Output is correct
46 Correct 639 ms 43580 KB Output is correct
47 Correct 1652 ms 108588 KB Output is correct
48 Correct 1535 ms 108568 KB Output is correct
49 Correct 1455 ms 108876 KB Output is correct
50 Correct 1458 ms 108536 KB Output is correct
51 Correct 1453 ms 108596 KB Output is correct
52 Correct 1581 ms 108804 KB Output is correct
53 Correct 1275 ms 108648 KB Output is correct
54 Correct 1062 ms 108576 KB Output is correct
55 Correct 7 ms 9672 KB Output is correct
56 Correct 363 ms 108160 KB Output is correct
57 Correct 1540 ms 108572 KB Output is correct
58 Correct 644 ms 26816 KB Output is correct
59 Correct 1377 ms 108536 KB Output is correct
60 Correct 497 ms 44732 KB Output is correct
61 Correct 1602 ms 108536 KB Output is correct
62 Correct 1779 ms 108552 KB Output is correct
63 Correct 1650 ms 108484 KB Output is correct
64 Correct 1543 ms 108536 KB Output is correct
65 Correct 1476 ms 108464 KB Output is correct
66 Correct 1545 ms 108820 KB Output is correct
67 Correct 1381 ms 108552 KB Output is correct
68 Correct 1448 ms 108500 KB Output is correct
69 Correct 6 ms 9672 KB Output is correct
70 Correct 7 ms 9672 KB Output is correct
71 Correct 9 ms 9800 KB Output is correct
72 Correct 8 ms 9800 KB Output is correct
73 Correct 8 ms 9800 KB Output is correct
74 Correct 9 ms 9720 KB Output is correct
75 Correct 10 ms 9788 KB Output is correct
76 Correct 6 ms 9672 KB Output is correct
77 Correct 7 ms 9672 KB Output is correct
78 Correct 8 ms 9672 KB Output is correct
79 Correct 9 ms 9800 KB Output is correct
80 Correct 9 ms 9800 KB Output is correct
81 Correct 10 ms 9800 KB Output is correct
82 Correct 9 ms 9800 KB Output is correct
83 Correct 9 ms 9800 KB Output is correct
84 Correct 7 ms 9800 KB Output is correct
85 Correct 10 ms 9800 KB Output is correct
86 Correct 36 ms 10568 KB Output is correct
87 Correct 19 ms 10568 KB Output is correct
88 Correct 26 ms 10568 KB Output is correct
89 Correct 35 ms 10568 KB Output is correct
90 Correct 34 ms 10568 KB Output is correct
91 Correct 7 ms 9800 KB Output is correct
92 Correct 8 ms 10056 KB Output is correct
93 Correct 28 ms 10568 KB Output is correct
94 Correct 31 ms 10612 KB Output is correct
95 Correct 33 ms 10568 KB Output is correct
96 Correct 36 ms 10568 KB Output is correct
97 Correct 26 ms 10576 KB Output is correct
98 Correct 8 ms 9672 KB Output is correct
99 Correct 294 ms 108440 KB Output is correct
100 Correct 299 ms 108524 KB Output is correct
101 Correct 278 ms 108548 KB Output is correct
102 Correct 292 ms 108536 KB Output is correct
103 Correct 313 ms 108944 KB Output is correct
104 Correct 267 ms 108552 KB Output is correct
105 Correct 7 ms 9672 KB Output is correct
106 Correct 171 ms 66612 KB Output is correct
107 Correct 307 ms 108496 KB Output is correct
108 Correct 278 ms 108564 KB Output is correct
109 Correct 294 ms 108664 KB Output is correct
110 Correct 332 ms 108892 KB Output is correct
111 Correct 266 ms 108664 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 6 ms 9672 KB Output is correct
2 Correct 6 ms 9672 KB Output is correct
3 Correct 376 ms 88772 KB Output is correct
4 Correct 1680 ms 108584 KB Output is correct
5 Correct 1385 ms 59196 KB Output is correct
6 Correct 1539 ms 108600 KB Output is correct
7 Correct 1162 ms 77648 KB Output is correct
8 Correct 1728 ms 108536 KB Output is correct
9 Correct 6 ms 9672 KB Output is correct
10 Correct 6 ms 9672 KB Output is correct
11 Correct 6 ms 9672 KB Output is correct
12 Correct 6 ms 9672 KB Output is correct
13 Correct 9 ms 9668 KB Output is correct
14 Correct 9 ms 9800 KB Output is correct
15 Correct 8 ms 9800 KB Output is correct
16 Correct 9 ms 9800 KB Output is correct
17 Correct 7 ms 9800 KB Output is correct
18 Correct 10 ms 9800 KB Output is correct
19 Correct 9 ms 9800 KB Output is correct
20 Correct 10 ms 9800 KB Output is correct
21 Correct 9 ms 9800 KB Output is correct
22 Correct 10 ms 9748 KB Output is correct
23 Correct 9 ms 9800 KB Output is correct
24 Correct 9 ms 9800 KB Output is correct
25 Correct 8 ms 9800 KB Output is correct
26 Correct 7 ms 9672 KB Output is correct
27 Correct 7 ms 9672 KB Output is correct
28 Correct 8 ms 9800 KB Output is correct
29 Correct 8 ms 9800 KB Output is correct
30 Correct 8 ms 9764 KB Output is correct
31 Correct 8 ms 9820 KB Output is correct
32 Correct 9 ms 9800 KB Output is correct
33 Correct 7 ms 9672 KB Output is correct
34 Correct 6 ms 9672 KB Output is correct
35 Correct 8 ms 9672 KB Output is correct
36 Correct 10 ms 9800 KB Output is correct
37 Correct 9 ms 9800 KB Output is correct
38 Correct 9 ms 9756 KB Output is correct
39 Correct 9 ms 9800 KB Output is correct
40 Correct 9 ms 9800 KB Output is correct
41 Correct 7 ms 9624 KB Output is correct
42 Correct 7 ms 9800 KB Output is correct
43 Correct 7 ms 9800 KB Output is correct
44 Correct 7 ms 9800 KB Output is correct
45 Correct 6 ms 9800 KB Output is correct
46 Correct 7 ms 9800 KB Output is correct
47 Correct 7 ms 9800 KB Output is correct
48 Correct 6 ms 9672 KB Output is correct
49 Correct 7 ms 9672 KB Output is correct
50 Correct 6 ms 9672 KB Output is correct
51 Correct 7 ms 9672 KB Output is correct
52 Correct 8 ms 9672 KB Output is correct
53 Correct 9 ms 9800 KB Output is correct
54 Correct 7 ms 9756 KB Output is correct
55 Correct 9 ms 9800 KB Output is correct
56 Correct 7 ms 9800 KB Output is correct
57 Correct 8 ms 9808 KB Output is correct
58 Correct 8 ms 9800 KB Output is correct
59 Correct 8 ms 9800 KB Output is correct
60 Correct 9 ms 9800 KB Output is correct
61 Correct 9 ms 9800 KB Output is correct
62 Correct 9 ms 9800 KB Output is correct
63 Correct 9 ms 9800 KB Output is correct
64 Correct 10 ms 9800 KB Output is correct
65 Correct 7 ms 9800 KB Output is correct
66 Correct 16 ms 10524 KB Output is correct
67 Correct 19 ms 10604 KB Output is correct
68 Correct 14 ms 10056 KB Output is correct
69 Correct 34 ms 10568 KB Output is correct
70 Correct 24 ms 9776 KB Output is correct
71 Correct 24 ms 10568 KB Output is correct
72 Correct 33 ms 10568 KB Output is correct
73 Correct 32 ms 10568 KB Output is correct
74 Correct 25 ms 10568 KB Output is correct
75 Correct 36 ms 10568 KB Output is correct
76 Correct 36 ms 10568 KB Output is correct
77 Correct 35 ms 10568 KB Output is correct
78 Correct 25 ms 10568 KB Output is correct
79 Correct 7 ms 9672 KB Output is correct
80 Correct 7 ms 9800 KB Output is correct
81 Correct 9 ms 9800 KB Output is correct
82 Correct 9 ms 9800 KB Output is correct
83 Correct 9 ms 9768 KB Output is correct
84 Correct 9 ms 9800 KB Output is correct
85 Correct 9 ms 9800 KB Output is correct
86 Correct 7 ms 9672 KB Output is correct
87 Correct 7 ms 9672 KB Output is correct
88 Correct 7 ms 9672 KB Output is correct
89 Correct 8 ms 9800 KB Output is correct
90 Correct 10 ms 9800 KB Output is correct
91 Correct 9 ms 9800 KB Output is correct
92 Correct 10 ms 9792 KB Output is correct
93 Correct 9 ms 9800 KB Output is correct
94 Correct 7 ms 9672 KB Output is correct
95 Correct 7 ms 9800 KB Output is correct
96 Correct 6 ms 9800 KB Output is correct
97 Correct 7 ms 9800 KB Output is correct
98 Correct 7 ms 9800 KB Output is correct
99 Correct 7 ms 9728 KB Output is correct
100 Correct 7 ms 9800 KB Output is correct
101 Correct 7 ms 9800 KB Output is correct
102 Correct 10 ms 9800 KB Output is correct
103 Correct 36 ms 10568 KB Output is correct
104 Correct 37 ms 10568 KB Output is correct
105 Correct 19 ms 10568 KB Output is correct
106 Correct 28 ms 10568 KB Output is correct
107 Correct 34 ms 10568 KB Output is correct
108 Correct 7 ms 9800 KB Output is correct
109 Correct 8 ms 10056 KB Output is correct
110 Correct 18 ms 10696 KB Output is correct
111 Correct 30 ms 10568 KB Output is correct
112 Correct 26 ms 10568 KB Output is correct
113 Correct 30 ms 10676 KB Output is correct
114 Correct 33 ms 10568 KB Output is correct
115 Correct 7 ms 9784 KB Output is correct
116 Correct 8 ms 10056 KB Output is correct
117 Correct 9 ms 10568 KB Output is correct
118 Correct 9 ms 10568 KB Output is correct
119 Correct 9 ms 10568 KB Output is correct
120 Correct 9 ms 10696 KB Output is correct
121 Correct 9 ms 10568 KB Output is correct
122 Correct 7 ms 9672 KB Output is correct
123 Correct 6 ms 9672 KB Output is correct
124 Correct 7 ms 9672 KB Output is correct
125 Correct 6 ms 9672 KB Output is correct
126 Correct 239 ms 89528 KB Output is correct
127 Correct 307 ms 108440 KB Output is correct
128 Correct 165 ms 60076 KB Output is correct
129 Correct 299 ms 108664 KB Output is correct
130 Correct 50 ms 24344 KB Output is correct
131 Correct 321 ms 108456 KB Output is correct
132 Correct 287 ms 108680 KB Output is correct
133 Correct 284 ms 108564 KB Output is correct
134 Correct 280 ms 108856 KB Output is correct
135 Correct 301 ms 108548 KB Output is correct
136 Correct 320 ms 108844 KB Output is correct
137 Correct 280 ms 108980 KB Output is correct
138 Correct 292 ms 108868 KB Output is correct
139 Correct 7 ms 9704 KB Output is correct
140 Correct 7 ms 9800 KB Output is correct
141 Correct 7 ms 9800 KB Output is correct
142 Correct 7 ms 9800 KB Output is correct
143 Correct 7 ms 9800 KB Output is correct
144 Correct 7 ms 9744 KB Output is correct
145 Correct 7 ms 9800 KB Output is correct
146 Correct 7 ms 9800 KB Output is correct
147 Correct 7 ms 10056 KB Output is correct
148 Correct 9 ms 10568 KB Output is correct
149 Correct 9 ms 10568 KB Output is correct
150 Correct 9 ms 10696 KB Output is correct
151 Correct 8 ms 10676 KB Output is correct
152 Correct 8 ms 10568 KB Output is correct
153 Correct 7 ms 9672 KB Output is correct
154 Correct 307 ms 108352 KB Output is correct
155 Correct 294 ms 108520 KB Output is correct
156 Correct 288 ms 108536 KB Output is correct
157 Correct 291 ms 108668 KB Output is correct
158 Correct 311 ms 108932 KB Output is correct
159 Correct 283 ms 108532 KB Output is correct
160 Correct 6 ms 9672 KB Output is correct
161 Correct 175 ms 66652 KB Output is correct
162 Correct 314 ms 108568 KB Output is correct
163 Correct 281 ms 108560 KB Output is correct
164 Correct 307 ms 108492 KB Output is correct
165 Correct 316 ms 108888 KB Output is correct
166 Correct 269 ms 108676 KB Output is correct
167 Correct 7 ms 9672 KB Output is correct
168 Correct 7 ms 9672 KB Output is correct
169 Correct 8 ms 9672 KB Output is correct
170 Correct 432 ms 54720 KB Output is correct
171 Correct 1405 ms 108568 KB Output is correct
172 Correct 748 ms 25800 KB Output is correct
173 Correct 1362 ms 108556 KB Output is correct
174 Correct 605 ms 43620 KB Output is correct
175 Correct 1548 ms 108536 KB Output is correct
176 Correct 1334 ms 108536 KB Output is correct
177 Correct 1573 ms 108876 KB Output is correct
178 Correct 1252 ms 108608 KB Output is correct
179 Correct 1529 ms 108536 KB Output is correct
180 Correct 1590 ms 108816 KB Output is correct
181 Correct 962 ms 108540 KB Output is correct
182 Correct 1189 ms 108548 KB Output is correct
183 Correct 7 ms 9672 KB Output is correct
184 Correct 7 ms 9672 KB Output is correct
185 Correct 7 ms 9672 KB Output is correct
186 Correct 8 ms 9800 KB Output is correct
187 Correct 8 ms 9800 KB Output is correct
188 Correct 9 ms 9732 KB Output is correct
189 Correct 10 ms 9800 KB Output is correct
190 Correct 9 ms 9772 KB Output is correct
191 Correct 7 ms 9800 KB Output is correct
192 Correct 8 ms 10056 KB Output is correct
193 Correct 18 ms 10568 KB Output is correct
194 Correct 34 ms 10652 KB Output is correct
195 Correct 27 ms 10568 KB Output is correct
196 Correct 18 ms 10568 KB Output is correct
197 Correct 27 ms 10568 KB Output is correct
198 Correct 6 ms 9672 KB Output is correct
199 Correct 176 ms 66636 KB Output is correct
200 Correct 295 ms 108536 KB Output is correct
201 Correct 299 ms 108620 KB Output is correct
202 Correct 297 ms 108436 KB Output is correct
203 Correct 322 ms 108940 KB Output is correct
204 Correct 272 ms 108536 KB Output is correct
205 Correct 7 ms 9672 KB Output is correct
206 Correct 7 ms 9672 KB Output is correct
207 Correct 7 ms 9672 KB Output is correct
208 Correct 417 ms 54712 KB Output is correct
209 Correct 1514 ms 108548 KB Output is correct
210 Correct 702 ms 25800 KB Output is correct
211 Correct 1372 ms 108572 KB Output is correct
212 Correct 639 ms 43580 KB Output is correct
213 Correct 1652 ms 108588 KB Output is correct
214 Correct 1535 ms 108568 KB Output is correct
215 Correct 1455 ms 108876 KB Output is correct
216 Correct 1458 ms 108536 KB Output is correct
217 Correct 1453 ms 108596 KB Output is correct
218 Correct 1581 ms 108804 KB Output is correct
219 Correct 1275 ms 108648 KB Output is correct
220 Correct 1062 ms 108576 KB Output is correct
221 Correct 7 ms 9672 KB Output is correct
222 Correct 363 ms 108160 KB Output is correct
223 Correct 1540 ms 108572 KB Output is correct
224 Correct 644 ms 26816 KB Output is correct
225 Correct 1377 ms 108536 KB Output is correct
226 Correct 497 ms 44732 KB Output is correct
227 Correct 1602 ms 108536 KB Output is correct
228 Correct 1779 ms 108552 KB Output is correct
229 Correct 1650 ms 108484 KB Output is correct
230 Correct 1543 ms 108536 KB Output is correct
231 Correct 1476 ms 108464 KB Output is correct
232 Correct 1545 ms 108820 KB Output is correct
233 Correct 1381 ms 108552 KB Output is correct
234 Correct 1448 ms 108500 KB Output is correct
235 Correct 6 ms 9672 KB Output is correct
236 Correct 7 ms 9672 KB Output is correct
237 Correct 9 ms 9800 KB Output is correct
238 Correct 8 ms 9800 KB Output is correct
239 Correct 8 ms 9800 KB Output is correct
240 Correct 9 ms 9720 KB Output is correct
241 Correct 10 ms 9788 KB Output is correct
242 Correct 6 ms 9672 KB Output is correct
243 Correct 7 ms 9672 KB Output is correct
244 Correct 8 ms 9672 KB Output is correct
245 Correct 9 ms 9800 KB Output is correct
246 Correct 9 ms 9800 KB Output is correct
247 Correct 10 ms 9800 KB Output is correct
248 Correct 9 ms 9800 KB Output is correct
249 Correct 9 ms 9800 KB Output is correct
250 Correct 7 ms 9800 KB Output is correct
251 Correct 10 ms 9800 KB Output is correct
252 Correct 36 ms 10568 KB Output is correct
253 Correct 19 ms 10568 KB Output is correct
254 Correct 26 ms 10568 KB Output is correct
255 Correct 35 ms 10568 KB Output is correct
256 Correct 34 ms 10568 KB Output is correct
257 Correct 7 ms 9800 KB Output is correct
258 Correct 8 ms 10056 KB Output is correct
259 Correct 28 ms 10568 KB Output is correct
260 Correct 31 ms 10612 KB Output is correct
261 Correct 33 ms 10568 KB Output is correct
262 Correct 36 ms 10568 KB Output is correct
263 Correct 26 ms 10576 KB Output is correct
264 Correct 8 ms 9672 KB Output is correct
265 Correct 294 ms 108440 KB Output is correct
266 Correct 299 ms 108524 KB Output is correct
267 Correct 278 ms 108548 KB Output is correct
268 Correct 292 ms 108536 KB Output is correct
269 Correct 313 ms 108944 KB Output is correct
270 Correct 267 ms 108552 KB Output is correct
271 Correct 7 ms 9672 KB Output is correct
272 Correct 171 ms 66612 KB Output is correct
273 Correct 307 ms 108496 KB Output is correct
274 Correct 278 ms 108564 KB Output is correct
275 Correct 294 ms 108664 KB Output is correct
276 Correct 332 ms 108892 KB Output is correct
277 Correct 266 ms 108664 KB Output is correct
278 Correct 7 ms 9656 KB Output is correct
279 Correct 6 ms 9672 KB Output is correct
280 Correct 7 ms 9672 KB Output is correct
281 Correct 354 ms 88768 KB Output is correct
282 Correct 1866 ms 108568 KB Output is correct
283 Correct 1316 ms 59172 KB Output is correct
284 Correct 1485 ms 108516 KB Output is correct
285 Correct 1363 ms 77536 KB Output is correct
286 Correct 1674 ms 108508 KB Output is correct
287 Correct 6 ms 9672 KB Output is correct
288 Correct 7 ms 9736 KB Output is correct
289 Correct 6 ms 9672 KB Output is correct
290 Correct 8 ms 9672 KB Output is correct
291 Correct 9 ms 9800 KB Output is correct
292 Correct 9 ms 9800 KB Output is correct
293 Correct 10 ms 9800 KB Output is correct
294 Correct 7 ms 9804 KB Output is correct
295 Correct 9 ms 9800 KB Output is correct
296 Correct 9 ms 9800 KB Output is correct
297 Correct 8 ms 9804 KB Output is correct
298 Correct 9 ms 9800 KB Output is correct
299 Correct 9 ms 9800 KB Output is correct
300 Correct 8 ms 9784 KB Output is correct
301 Correct 8 ms 9800 KB Output is correct
302 Correct 10 ms 9800 KB Output is correct
303 Correct 7 ms 9800 KB Output is correct
304 Correct 27 ms 10488 KB Output is correct
305 Correct 36 ms 10568 KB Output is correct
306 Correct 13 ms 10056 KB Output is correct
307 Correct 33 ms 10568 KB Output is correct
308 Correct 22 ms 9800 KB Output is correct
309 Correct 22 ms 10568 KB Output is correct
310 Correct 36 ms 10568 KB Output is correct
311 Correct 33 ms 10568 KB Output is correct
312 Correct 27 ms 10568 KB Output is correct
313 Correct 28 ms 10568 KB Output is correct
314 Correct 27 ms 10568 KB Output is correct
315 Correct 26 ms 10568 KB Output is correct
316 Correct 23 ms 10568 KB Output is correct
317 Correct 7 ms 9672 KB Output is correct
318 Correct 7 ms 9672 KB Output is correct
319 Correct 7 ms 9672 KB Output is correct
320 Correct 237 ms 89504 KB Output is correct
321 Correct 330 ms 108452 KB Output is correct
322 Correct 153 ms 59980 KB Output is correct
323 Correct 298 ms 108536 KB Output is correct
324 Correct 46 ms 24264 KB Output is correct
325 Correct 313 ms 108488 KB Output is correct
326 Correct 278 ms 108552 KB Output is correct
327 Correct 278 ms 108528 KB Output is correct
328 Correct 275 ms 108852 KB Output is correct
329 Correct 299 ms 108628 KB Output is correct
330 Correct 313 ms 108856 KB Output is correct
331 Correct 288 ms 108852 KB Output is correct
332 Correct 300 ms 108976 KB Output is correct
333 Correct 7 ms 9672 KB Output is correct
334 Correct 6 ms 9672 KB Output is correct
335 Correct 6 ms 9672 KB Output is correct
336 Correct 343 ms 54856 KB Output is correct
337 Correct 1260 ms 108480 KB Output is correct
338 Correct 856 ms 25836 KB Output is correct
339 Correct 1176 ms 108536 KB Output is correct
340 Correct 782 ms 43580 KB Output is correct
341 Correct 1348 ms 108536 KB Output is correct
342 Correct 1318 ms 108536 KB Output is correct
343 Correct 1501 ms 108896 KB Output is correct
344 Correct 1290 ms 108536 KB Output is correct
345 Correct 1323 ms 108556 KB Output is correct
346 Correct 1495 ms 108884 KB Output is correct
347 Correct 1143 ms 108536 KB Output is correct
348 Correct 1424 ms 108564 KB Output is correct
349 Correct 6 ms 9672 KB Output is correct
350 Correct 365 ms 108152 KB Output is correct
351 Correct 1627 ms 108564 KB Output is correct
352 Correct 708 ms 26868 KB Output is correct
353 Correct 1454 ms 108536 KB Output is correct
354 Correct 573 ms 44656 KB Output is correct
355 Correct 1549 ms 108524 KB Output is correct
356 Correct 1554 ms 108512 KB Output is correct
357 Correct 1604 ms 108556 KB Output is correct
358 Correct 1697 ms 108536 KB Output is correct
359 Correct 1617 ms 108536 KB Output is correct
360 Correct 1524 ms 108812 KB Output is correct
361 Correct 1359 ms 108552 KB Output is correct
362 Correct 1447 ms 108680 KB Output is correct
363 Correct 7 ms 9672 KB Output is correct
364 Correct 785 ms 62396 KB Output is correct
365 Correct 1464 ms 108536 KB Output is correct
366 Correct 560 ms 80692 KB Output is correct
367 Correct 1515 ms 108544 KB Output is correct
368 Correct 559 ms 50044 KB Output is correct
369 Correct 1578 ms 108572 KB Output is correct
370 Correct 1699 ms 108612 KB Output is correct
371 Correct 1594 ms 108536 KB Output is correct
372 Correct 1609 ms 108520 KB Output is correct
373 Correct 1516 ms 108664 KB Output is correct
374 Correct 1648 ms 108936 KB Output is correct
375 Correct 1674 ms 108540 KB Output is correct
376 Correct 1599 ms 108588 KB Output is correct
377 Correct 7 ms 9672 KB Output is correct
378 Correct 8 ms 9672 KB Output is correct
379 Correct 9 ms 9800 KB Output is correct
380 Correct 9 ms 9800 KB Output is correct
381 Correct 9 ms 9800 KB Output is correct
382 Correct 9 ms 9800 KB Output is correct
383 Correct 9 ms 9800 KB Output is correct
384 Correct 7 ms 9672 KB Output is correct
385 Correct 7 ms 9672 KB Output is correct
386 Correct 7 ms 9672 KB Output is correct
387 Correct 9 ms 9800 KB Output is correct
388 Correct 10 ms 9800 KB Output is correct
389 Correct 10 ms 9800 KB Output is correct
390 Correct 9 ms 9800 KB Output is correct
391 Correct 10 ms 9800 KB Output is correct
392 Correct 7 ms 9672 KB Output is correct
393 Correct 7 ms 9800 KB Output is correct
394 Correct 7 ms 9752 KB Output is correct
395 Correct 7 ms 9800 KB Output is correct
396 Correct 7 ms 9800 KB Output is correct
397 Correct 7 ms 9800 KB Output is correct
398 Correct 7 ms 9800 KB Output is correct
399 Correct 7 ms 9800 KB Output is correct
400 Correct 10 ms 9800 KB Output is correct
401 Correct 38 ms 10568 KB Output is correct
402 Correct 33 ms 10568 KB Output is correct
403 Correct 37 ms 10568 KB Output is correct
404 Correct 26 ms 10568 KB Output is correct
405 Correct 36 ms 10568 KB Output is correct
406 Correct 7 ms 9736 KB Output is correct
407 Correct 8 ms 10056 KB Output is correct
408 Correct 36 ms 10588 KB Output is correct
409 Correct 25 ms 10568 KB Output is correct
410 Correct 24 ms 10644 KB Output is correct
411 Correct 32 ms 10568 KB Output is correct
412 Correct 33 ms 10568 KB Output is correct
413 Correct 7 ms 9800 KB Output is correct
414 Correct 8 ms 10056 KB Output is correct
415 Correct 8 ms 10568 KB Output is correct
416 Correct 9 ms 10628 KB Output is correct
417 Correct 9 ms 10632 KB Output is correct
418 Correct 8 ms 10568 KB Output is correct
419 Correct 8 ms 10568 KB Output is correct
420 Correct 6 ms 9672 KB Output is correct
421 Correct 295 ms 108364 KB Output is correct
422 Correct 304 ms 108536 KB Output is correct
423 Correct 281 ms 108584 KB Output is correct
424 Correct 294 ms 108536 KB Output is correct
425 Correct 311 ms 108840 KB Output is correct
426 Correct 271 ms 108504 KB Output is correct
427 Correct 6 ms 9672 KB Output is correct
428 Correct 174 ms 66580 KB Output is correct
429 Correct 304 ms 108600 KB Output is correct
430 Correct 276 ms 108572 KB Output is correct
431 Correct 288 ms 108536 KB Output is correct
432 Correct 318 ms 108816 KB Output is correct
433 Correct 264 ms 108608 KB Output is correct