Submission #52760

#TimeUsernameProblemLanguageResultExecution timeMemory
52760SmelskiyFortune Telling 2 (JOI14_fortune_telling2)C++14
4 / 100
3041 ms1516 KiB
#include <bits/stdc++.h> using namespace std; int n,m; int q[2000005]; int t1[2000005]; int t2[2000005]; pair<int,int> a[200005]; int sz; inline void push(int x) { if (!q[x]) return; q[x+x]^=1; q[x+x+1]^=1; q[x]=0; swap(t1[x+x],t2[x+x]); swap(t1[x+x+1],t2[x+x+1]); } void dfs(int l,int r,int x,int y) { if (t1[x]<=y) { swap(t1[x],t2[x]); q[x]^=1; return; } if (l==r) return; int mid=(l+r)>>1; push(x); dfs(l,mid,x+x,y); dfs(mid+1,r,x+x+1,y); t1[x]=max(t1[x+x],t1[x+x+1]); t2[x]=max(t2[x+x],t2[x+x+1]); } long long ans=0; void solve(int l,int r,int x) { if (l>n) return; if (l==r) { ans+=t1[x]; return; } push(x); int mid=(l+r)>>1; solve(l,mid,x+x); solve(mid+1,r,x+x+1); } inline bool cmp(pair<int,int> x,pair<int,int> y) { return max(x.first,x.second)<max(y.first,y.second); } int main() { ios_base::sync_with_stdio(false); cin.tie(0); cout.tie(0); cin>>n>>m; for (int i=1;i<=n;++i) { cin>>a[i].first>>a[i].second; } sort(a+1,a+n+1,cmp); sz=1; while (sz<n) sz+=sz; for (int i=1;i<=n;++i) { t1[sz+i-1]=a[i].first; t2[sz+i-1]=a[i].second; } for (int i=sz-1;i>0;--i) { t1[i]=max(t1[i+i],t1[i+i+1]); t2[i]=max(t2[i+i],t2[i+i+1]); } int x; for (int i=1;i<=m;++i) { cin>>x; dfs(1,sz,1,x); } solve(1,sz,1); cout<<ans; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...