#include"sequence.h"
#include<vector>
#include<iostream>
using namespace std;
const int TREE_SIZE=1<<19;
int n;
vector<int>arr[500000];
int tree_lazy[2*TREE_SIZE];
int tree_min[2*TREE_SIZE];
int tree_max[2*TREE_SIZE];
void push_lazy(int node){
if(tree_lazy[node]!=0){
tree_min[node]+=tree_lazy[node];
tree_max[node]+=tree_lazy[node];
if(node<TREE_SIZE){
tree_lazy[2*node]+=tree_lazy[node];
tree_lazy[2*node+1]+=tree_lazy[node];
}
tree_lazy[node]=0;
}
}
int get_min(int node,int rl,int rr,int l,int r){
push_lazy(node);
if(r<=rl||rr<=l)
return 1e8;
if(l<=rl&&rr<=r)
return tree_min[node];
int mid=(rl+rr)/2;
return min(get_min(2*node,rl,mid,l,r),get_min(2*node+1,mid,rr,l,r));
}
int get_max(int node,int rl,int rr,int l,int r){
push_lazy(node);
if(r<=rl||rr<=l)
return -1e8;
if(l<=rl&&rr<=r)
return tree_max[node];
int mid=(rl+rr)/2;
return max(get_max(2*node,rl,mid,l,r),get_max(2*node+1,mid,rr,l,r));
}
int get_min(int l,int r){
return get_min(1,0,TREE_SIZE,l,r);
}
int get_max(int l,int r){
return get_max(1,0,TREE_SIZE,l,r);
}
void add(int node,int rl,int rr,int l,int r,int v){
push_lazy(node);
if(r<=rl||rr<=l)
return;
if(l<=rl&&rr<=r){
tree_lazy[node]+=v;
push_lazy(node);
return;
}
int mid=(rl+rr)/2;
add(2*node,rl,mid,l,r,v);
add(2*node+1,mid,rr,l,r,v);
tree_min[node]=min(tree_min[2*node],tree_min[2*node+1]);
tree_max[node]=max(tree_max[2*node],tree_max[2*node+1]);
}
void add(int l,int r,int v){
add(1,0,TREE_SIZE,l,r,v);
}
int sequence(int N,vector<int>A){
n=N;
for(int i=0;i<n;i++)
arr[A[i]-1].push_back(i);
/*for(int i=0;i<=n;i++)
tree[i]=-i;*/
for(int i=0;i<=n;i++)
add(i,i+1,-i);
int res=1;
for(int v=0;v<n;v++){
for(int idx:arr[v])
/*for(int i=idx+1;i<=n;i++)
tree[i]++;*/
add(idx+1,n+1,1);
vector<int>mn1,mn2,mx1,mx2;
for(int i:arr[v]){
mn1.push_back(get_min(0,i+1));
mn2.push_back(get_min(i,n+1));
mx1.push_back(get_max(0,i+1));
mx2.push_back(get_max(i,n+1));
}
int l=0;
for(int r=0;r<(int)arr[v].size();r++){
l=max(0,l-100);
int min2=mn2[r];
int max2=mx2[r];
int min1=mn1[l];
int max1=mx1[l];
while(l<r&&(max1-l+1<min2-r||max2+r+1<min1+l)){
l++;
min1=mn1[l];
max1=mx1[l];
}
res=max(res,r-l+1);
}
for(int idx:arr[v])
/*for(int i=idx+1;i<=n;i++)
tree[i]++;*/
add(idx+1,n+1,1);
}
return res;
}
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
4 ms |
15960 KB |
Output is correct |
2 |
Correct |
4 ms |
15960 KB |
Output is correct |
3 |
Correct |
4 ms |
15964 KB |
Output is correct |
4 |
Correct |
4 ms |
15960 KB |
Output is correct |
5 |
Correct |
4 ms |
15960 KB |
Output is correct |
6 |
Correct |
4 ms |
15960 KB |
Output is correct |
7 |
Correct |
4 ms |
15964 KB |
Output is correct |
8 |
Correct |
5 ms |
15960 KB |
Output is correct |
9 |
Correct |
4 ms |
15960 KB |
Output is correct |
10 |
Correct |
4 ms |
15964 KB |
Output is correct |
11 |
Correct |
5 ms |
15960 KB |
Output is correct |
12 |
Correct |
4 ms |
15964 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
4 ms |
15960 KB |
Output is correct |
2 |
Correct |
4 ms |
15960 KB |
Output is correct |
3 |
Correct |
4 ms |
15964 KB |
Output is correct |
4 |
Correct |
4 ms |
15960 KB |
Output is correct |
5 |
Correct |
4 ms |
15960 KB |
Output is correct |
6 |
Correct |
4 ms |
15960 KB |
Output is correct |
7 |
Correct |
4 ms |
15964 KB |
Output is correct |
8 |
Correct |
5 ms |
15960 KB |
Output is correct |
9 |
Correct |
4 ms |
15960 KB |
Output is correct |
10 |
Correct |
4 ms |
15964 KB |
Output is correct |
11 |
Correct |
5 ms |
15960 KB |
Output is correct |
12 |
Correct |
4 ms |
15964 KB |
Output is correct |
13 |
Correct |
8 ms |
16216 KB |
Output is correct |
14 |
Correct |
9 ms |
16216 KB |
Output is correct |
15 |
Correct |
8 ms |
16216 KB |
Output is correct |
16 |
Correct |
8 ms |
16216 KB |
Output is correct |
17 |
Correct |
8 ms |
16216 KB |
Output is correct |
18 |
Correct |
8 ms |
16216 KB |
Output is correct |
19 |
Correct |
9 ms |
16216 KB |
Output is correct |
20 |
Correct |
8 ms |
16216 KB |
Output is correct |
21 |
Correct |
10 ms |
16216 KB |
Output is correct |
22 |
Correct |
10 ms |
16216 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
4 ms |
15960 KB |
Output is correct |
2 |
Correct |
1282 ms |
38080 KB |
Output is correct |
3 |
Correct |
1315 ms |
38004 KB |
Output is correct |
4 |
Correct |
1205 ms |
33156 KB |
Output is correct |
5 |
Correct |
1281 ms |
37000 KB |
Output is correct |
6 |
Correct |
1287 ms |
36936 KB |
Output is correct |
7 |
Correct |
1195 ms |
30652 KB |
Output is correct |
8 |
Correct |
1203 ms |
30700 KB |
Output is correct |
9 |
Correct |
1209 ms |
34224 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
4 ms |
15960 KB |
Output is correct |
2 |
Correct |
1107 ms |
39420 KB |
Output is correct |
3 |
Correct |
1121 ms |
35008 KB |
Output is correct |
4 |
Correct |
1225 ms |
35256 KB |
Output is correct |
5 |
Correct |
1221 ms |
39384 KB |
Output is correct |
6 |
Correct |
1208 ms |
36248 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
1395 ms |
43576 KB |
Output is correct |
2 |
Correct |
1354 ms |
43856 KB |
Output is correct |
3 |
Correct |
1398 ms |
43356 KB |
Output is correct |
4 |
Correct |
1355 ms |
43232 KB |
Output is correct |
5 |
Correct |
1358 ms |
39824 KB |
Output is correct |
6 |
Correct |
1394 ms |
39760 KB |
Output is correct |
7 |
Correct |
1266 ms |
38568 KB |
Output is correct |
8 |
Correct |
1278 ms |
38480 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
4 ms |
15960 KB |
Output is correct |
2 |
Correct |
4 ms |
15960 KB |
Output is correct |
3 |
Correct |
4 ms |
15964 KB |
Output is correct |
4 |
Correct |
4 ms |
15960 KB |
Output is correct |
5 |
Correct |
4 ms |
15960 KB |
Output is correct |
6 |
Correct |
4 ms |
15960 KB |
Output is correct |
7 |
Correct |
4 ms |
15964 KB |
Output is correct |
8 |
Correct |
5 ms |
15960 KB |
Output is correct |
9 |
Correct |
4 ms |
15960 KB |
Output is correct |
10 |
Correct |
4 ms |
15964 KB |
Output is correct |
11 |
Correct |
5 ms |
15960 KB |
Output is correct |
12 |
Correct |
4 ms |
15964 KB |
Output is correct |
13 |
Correct |
8 ms |
16216 KB |
Output is correct |
14 |
Correct |
9 ms |
16216 KB |
Output is correct |
15 |
Correct |
8 ms |
16216 KB |
Output is correct |
16 |
Correct |
8 ms |
16216 KB |
Output is correct |
17 |
Correct |
8 ms |
16216 KB |
Output is correct |
18 |
Correct |
8 ms |
16216 KB |
Output is correct |
19 |
Correct |
9 ms |
16216 KB |
Output is correct |
20 |
Correct |
8 ms |
16216 KB |
Output is correct |
21 |
Correct |
10 ms |
16216 KB |
Output is correct |
22 |
Correct |
10 ms |
16216 KB |
Output is correct |
23 |
Correct |
238 ms |
19976 KB |
Output is correct |
24 |
Correct |
200 ms |
19976 KB |
Output is correct |
25 |
Correct |
242 ms |
19976 KB |
Output is correct |
26 |
Correct |
216 ms |
19184 KB |
Output is correct |
27 |
Correct |
220 ms |
19056 KB |
Output is correct |
28 |
Correct |
206 ms |
19024 KB |
Output is correct |
29 |
Correct |
194 ms |
19056 KB |
Output is correct |
30 |
Correct |
195 ms |
19024 KB |
Output is correct |
31 |
Correct |
187 ms |
20936 KB |
Output is correct |
32 |
Correct |
172 ms |
20804 KB |
Output is correct |
33 |
Incorrect |
197 ms |
19972 KB |
Output isn't correct |
34 |
Halted |
0 ms |
0 KB |
- |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
4 ms |
15960 KB |
Output is correct |
2 |
Correct |
4 ms |
15960 KB |
Output is correct |
3 |
Correct |
4 ms |
15964 KB |
Output is correct |
4 |
Correct |
4 ms |
15960 KB |
Output is correct |
5 |
Correct |
4 ms |
15960 KB |
Output is correct |
6 |
Correct |
4 ms |
15960 KB |
Output is correct |
7 |
Correct |
4 ms |
15964 KB |
Output is correct |
8 |
Correct |
5 ms |
15960 KB |
Output is correct |
9 |
Correct |
4 ms |
15960 KB |
Output is correct |
10 |
Correct |
4 ms |
15964 KB |
Output is correct |
11 |
Correct |
5 ms |
15960 KB |
Output is correct |
12 |
Correct |
4 ms |
15964 KB |
Output is correct |
13 |
Correct |
8 ms |
16216 KB |
Output is correct |
14 |
Correct |
9 ms |
16216 KB |
Output is correct |
15 |
Correct |
8 ms |
16216 KB |
Output is correct |
16 |
Correct |
8 ms |
16216 KB |
Output is correct |
17 |
Correct |
8 ms |
16216 KB |
Output is correct |
18 |
Correct |
8 ms |
16216 KB |
Output is correct |
19 |
Correct |
9 ms |
16216 KB |
Output is correct |
20 |
Correct |
8 ms |
16216 KB |
Output is correct |
21 |
Correct |
10 ms |
16216 KB |
Output is correct |
22 |
Correct |
10 ms |
16216 KB |
Output is correct |
23 |
Correct |
1282 ms |
38080 KB |
Output is correct |
24 |
Correct |
1315 ms |
38004 KB |
Output is correct |
25 |
Correct |
1205 ms |
33156 KB |
Output is correct |
26 |
Correct |
1281 ms |
37000 KB |
Output is correct |
27 |
Correct |
1287 ms |
36936 KB |
Output is correct |
28 |
Correct |
1195 ms |
30652 KB |
Output is correct |
29 |
Correct |
1203 ms |
30700 KB |
Output is correct |
30 |
Correct |
1209 ms |
34224 KB |
Output is correct |
31 |
Correct |
1107 ms |
39420 KB |
Output is correct |
32 |
Correct |
1121 ms |
35008 KB |
Output is correct |
33 |
Correct |
1225 ms |
35256 KB |
Output is correct |
34 |
Correct |
1221 ms |
39384 KB |
Output is correct |
35 |
Correct |
1208 ms |
36248 KB |
Output is correct |
36 |
Correct |
1395 ms |
43576 KB |
Output is correct |
37 |
Correct |
1354 ms |
43856 KB |
Output is correct |
38 |
Correct |
1398 ms |
43356 KB |
Output is correct |
39 |
Correct |
1355 ms |
43232 KB |
Output is correct |
40 |
Correct |
1358 ms |
39824 KB |
Output is correct |
41 |
Correct |
1394 ms |
39760 KB |
Output is correct |
42 |
Correct |
1266 ms |
38568 KB |
Output is correct |
43 |
Correct |
1278 ms |
38480 KB |
Output is correct |
44 |
Correct |
238 ms |
19976 KB |
Output is correct |
45 |
Correct |
200 ms |
19976 KB |
Output is correct |
46 |
Correct |
242 ms |
19976 KB |
Output is correct |
47 |
Correct |
216 ms |
19184 KB |
Output is correct |
48 |
Correct |
220 ms |
19056 KB |
Output is correct |
49 |
Correct |
206 ms |
19024 KB |
Output is correct |
50 |
Correct |
194 ms |
19056 KB |
Output is correct |
51 |
Correct |
195 ms |
19024 KB |
Output is correct |
52 |
Correct |
187 ms |
20936 KB |
Output is correct |
53 |
Correct |
172 ms |
20804 KB |
Output is correct |
54 |
Incorrect |
197 ms |
19972 KB |
Output isn't correct |
55 |
Halted |
0 ms |
0 KB |
- |