This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include<bits/stdc++.h>
using namespace std;
typedef long long int ll;
const int MAXN = 5e5+2;
int n, k, last[MAXN], lc[MAXN], nxt[MAXN], ff[MAXN];
ll md, seg[MAXN*4], ans = 0;
pair<int,int> f[MAXN], all[MAXN];
void add(int x, int b = 0, int e = k, int ind = 1){
if(b+1 == e){
seg[ind] = (seg[ind]+1)%md;
return;
}
int mid = (b + e) / 2;
if(x < mid) add(x, b, mid, ind * 2);
else add(x, mid, e, ind * 2 + 1);
seg[ind] = (seg[ind*2]*seg[ind*2+1])%md;
return;
}
ll get(int l, int r, int b = 0, int e = k, int ind = 1){
if(r <= b || e <= l) return 1ll;
if(l <= b && r >= e) return seg[ind];
int mid = (b + e) / 2; ll res = 1ll;
res = (res*get(l, r, b, mid, ind * 2))%md;
res = (res*get(l, r, mid, e, ind * 2 + 1))%md;
return res;
}
int main()
{
ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0);
for(int i = 0; i < MAXN*4; i++) seg[i] = 1ll;
cin >> n >> k >> md;
for(int i = 0; i < n; i++){
cin >> f[i].first >> f[i].second; f[i].second--;
all[f[i].second].second = f[i].second, all[f[i].second].first = max(all[f[i].second].first,f[i].first);
}
sort(f,f+n);
sort(all,all+k);
// cout << "all:";
// for(int i = 0; i < k; i++) cout << all[i].first << ":" << all[i].second+1 << " ";
// cout << endl;
for(int i = 0; i < k; i++) last[all[i].second] = i, lc[i] = -1;
for(int i = 0; i < n; i++){
if(lc[f[i].second]!=-1) nxt[lc[f[i].second]] = i;
else ff[f[i].second] = i;
lc[f[i].second] = i;
}
for(int i = 0; i < k; i++) lc[i] = -1;
int pt = 0;
for(int i = 0; i < k; i++){
int cl = all[i].second, l = all[i].first;
//cout << "i:" << i << " cl:" << cl+1 << " l:" << l << endl;
while(pt<n && l>=2*f[pt].first){
lc[f[pt].second] = pt;
add(last[f[pt].second]); pt++;
}
//cout << "pt:" << pt << endl;
ll mul1 = get(0,i), tr = get(i,i+1), mul2;//get0,i-1
int ii = (lc[cl]==-1?ff[cl]:nxt[lc[cl]]);
pair<int,int> p = {2*f[ii].first,0};
int ind = lower_bound(all,all+k,p)-all;
mul2 = get(i+1,ind);
ans = (ans+((mul1*tr)%md))%md; ans = (ans+((mul1*mul2)%md))%md;
}
cout << ans << endl;
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |