#include <iostream>
#include <vector>
#include <map>
#include <algorithm>
#pragma pack(1)
#pragma GCC optimize("Ofast,unroll-loops")
using namespace std;
typedef long long ll;
typedef pair <int, int> pii;
const int NMAX = 100000;
const int VMAX = NMAX * 89;
int total = 0;
int nxt[NMAX * 100];
int val[NMAX * 100];
class lista{
public:
int cnt = 0;
int primul = 0;
int ultimul = 0;
void init(){
cnt = primul = ultimul = 0;
}
void clear(){
cnt = 0;
primul = 0;
ultimul = 0;
}
void push_back(int x){
if(cnt == 0){
primul = ultimul = ++total;
}else{
nxt[ultimul] = ++total;
ultimul = total;
}
cnt++;
val[total] = x;
}
};
int a[NMAX], n;
int u;
int cc = 0;
int l[VMAX];
int r[VMAX];
lista v[VMAX];
bool ok;
int root[NMAX];
vector <int> parcurgere[2];
inline void update(int node, int st, int dr, int a, int b, int val){
if(a <= st && dr <= b){
v[node].push_back(val);
return;
}
int mid = (st + dr) / 2;
if(a <= mid){
if(l[node] == 0){
l[node] = ++cc;
}
update(l[node], st, mid, a, b, val);
}
if(b > mid){
if(r[node] == 0){
r[node] = ++cc;
}
update(r[node], mid + 1, dr, a, b, val);
}
}
inline void query(int node, int st, int dr, int aa){
if(node == 0)
return;
//parcurgere[ok].clear();
int t = v[node].primul;
while(t != 0){
parcurgere[ok].push_back(a[val[t]]);
t = nxt[t];
}
int mid = (st + dr) / 2;
if(aa <= mid)
query(l[node], st, mid, aa);
else
query(r[node], mid + 1, dr, aa);
}
void init(int N, int D, int H[]) {
n = N;
for(int i = 0; i < N; i++) {
a[i] = H[i];
root[i] = ++cc;
}
}
map <pii, int> mp;
void curseChanges(int U, int A[], int B[]) {
u = U;
for(int i = 0; i < U; i++){
if(A[i] > B[i])
swap(A[i], B[i]);
pii x = {A[i], B[i]};
if(mp[x] == 0)
mp[x] = i + 1;
else{
update(root[x.first], 0, U, mp[x], i, x.second);
update(root[x.second], 0, U, mp[x], i, x.first);
mp[x] = 0;
}
}
for(auto y : mp){
pii x = y.first;
if(mp[x] != 0){
update(root[x.first], 0, U, mp[x], U, x.second);
update(root[x.second], 0, U, mp[x], U, x.first);
}
}
mp.clear();
}
int question(int x, int y, int v) {
int minim = 1e9;
ok = 0;
parcurgere[ok].clear();
query(root[x], 0, u, v);
if(!parcurgere[ok].size()) return minim;
ok = 1;
parcurgere[ok].clear();
query(root[y], 0, u, v);
if(!parcurgere[ok].size()) return minim;
sort(parcurgere[0].begin(), parcurgere[0].end());
sort(parcurgere[1].begin(), parcurgere[1].end());
//assert(cc <= NMAX * 36);
int i = 0, j = 0;
while(i < parcurgere[0].size() && j < parcurgere[1].size()){
minim = min(minim, abs(parcurgere[0][i] - parcurgere[1][j]));
if(parcurgere[0][i] < parcurgere[1][j])
i++;
else
j++;
}
return minim;
}
Compilation message
potion.cpp: In function 'int question(int, int, int)':
potion.cpp:141:13: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
141 | while(i < parcurgere[0].size() && j < parcurgere[1].size()){
| ~~^~~~~~~~~~~~~~~~~~~~~~
potion.cpp:141:41: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
141 | while(i < parcurgere[0].size() && j < parcurgere[1].size()){
| ~~^~~~~~~~~~~~~~~~~~~~~~
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
0 ms |
336 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
3 ms |
976 KB |
Output is correct |
2 |
Correct |
2 ms |
976 KB |
Output is correct |
3 |
Correct |
3 ms |
976 KB |
Output is correct |
4 |
Correct |
18 ms |
2920 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
557 ms |
216168 KB |
Output is correct |
2 |
Correct |
568 ms |
216068 KB |
Output is correct |
3 |
Correct |
268 ms |
77332 KB |
Output is correct |
4 |
Correct |
2375 ms |
134204 KB |
Output is correct |
5 |
Correct |
937 ms |
178936 KB |
Output is correct |
6 |
Execution timed out |
3076 ms |
160968 KB |
Time limit exceeded |
7 |
Halted |
0 ms |
0 KB |
- |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
615 ms |
215968 KB |
Output is correct |
2 |
Correct |
2511 ms |
108084 KB |
Output is correct |
3 |
Correct |
1919 ms |
166288 KB |
Output is correct |
4 |
Execution timed out |
3027 ms |
160964 KB |
Time limit exceeded |
5 |
Halted |
0 ms |
0 KB |
- |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
65 ms |
8664 KB |
Output is correct |
2 |
Correct |
78 ms |
4708 KB |
Output is correct |
3 |
Correct |
116 ms |
3472 KB |
Output is correct |
4 |
Correct |
719 ms |
6608 KB |
Output is correct |
5 |
Correct |
633 ms |
7632 KB |
Output is correct |
6 |
Correct |
105 ms |
6992 KB |
Output is correct |
7 |
Correct |
552 ms |
4816 KB |
Output is correct |
# |
Verdict |
Execution time |
Memory |
Grader output |
1 |
Correct |
0 ms |
336 KB |
Output is correct |
2 |
Correct |
3 ms |
976 KB |
Output is correct |
3 |
Correct |
2 ms |
976 KB |
Output is correct |
4 |
Correct |
3 ms |
976 KB |
Output is correct |
5 |
Correct |
18 ms |
2920 KB |
Output is correct |
6 |
Correct |
557 ms |
216168 KB |
Output is correct |
7 |
Correct |
568 ms |
216068 KB |
Output is correct |
8 |
Correct |
268 ms |
77332 KB |
Output is correct |
9 |
Correct |
2375 ms |
134204 KB |
Output is correct |
10 |
Correct |
937 ms |
178936 KB |
Output is correct |
11 |
Execution timed out |
3076 ms |
160968 KB |
Time limit exceeded |
12 |
Halted |
0 ms |
0 KB |
- |