제출 #966426

#제출 시각아이디문제언어결과실행 시간메모리
966426ttamxCake 3 (JOI19_cake3)C++17
100 / 100
1708 ms25840 KiB
#include<bits/stdc++.h> using namespace std; using ll = long long; using t4 = tuple<int,int,int,int>; const int N=2e5+5; const int K=1<<19; const ll INF=LLONG_MAX/2; int n,m; ll v[N],c[N],pos[N]; ll ans=-INF; pair<int,int> a[N]; vector<pair<int,int>> vec; vector<t4> q; struct Node{ ll sum; int freq; Node():sum(0),freq(0){} Node(ll x):sum(x),freq(1){} Node(ll x,int f):sum(x),freq(f){} friend Node operator+(const Node &lhs,const Node &rhs){ return Node(lhs.sum+rhs.sum,lhs.freq+rhs.freq); } }; struct SegTree{ Node t[K]; void build(int l,int r,int i){ t[i]=Node(); if(l==r)return; int m=(l+r)/2; build(l,m,i*2); build(m+1,r,i*2+1); } void build(){ build(1,n,1); } void update(int l,int r,int i,int x,const Node &v){ if(x<l||r<x)return; if(l==r)return void(t[i]=v); int m=(l+r)/2; update(l,m,i*2,x,v); update(m+1,r,i*2+1,x,v); t[i]=t[i*2]+t[i*2+1]; } void update(int x,const Node &v){ update(1,n,1,x,v); } ll query(int l,int r,int i,int k){ if(l==r)return t[i].sum; int m=(l+r)/2; if(t[i*2+1].freq<k)return query(l,m,i*2,k-t[i*2+1].freq)+t[i*2+1].sum; return query(m+1,r,i*2+1,k); } ll query(int k){ return query(1,n,1,k); } }s; int st=1,ed=0; void work(int l,int r){ while(ed<r){ ed++; s.update(pos[ed],Node(v[ed])); } while(st>l){ st--; s.update(pos[st],Node(v[st])); } while(ed>r){ s.update(pos[ed],Node()); ed--; } while(st<l){ s.update(pos[st],Node()); st++; } } int main(){ cin.tie(nullptr)->sync_with_stdio(false); cin >> n >> m; for(int i=1;i<=n;i++)cin >> a[i].second >> a[i].first; sort(a+1,a+n+1); for(int i=1;i<=n;i++){ tie(c[i],v[i])=a[i]; vec.emplace_back(v[i],i); } sort(vec.begin(),vec.end()); for(int i=0;i<n;i++)pos[vec[i].second]=i+1; q.emplace_back(1,n-m+1,1,n); while(!q.empty()){ vector<t4> nq; for(auto [l,r,optl,optr]:q){ if(l>r)continue; int mid=(l+r)/2; ll res=-INF; int opt=-1; for(int i=max(mid+m-1,optl),cnt=0;i<=optr;i++){ work(mid,i); ll tmp=s.query(m)-2*c[i]; if(tmp>res)res=tmp,opt=i; } res+=2*c[mid]; ans=max(ans,res); nq.emplace_back(l,mid-1,optl,opt); nq.emplace_back(mid+1,r,opt,optr); } swap(q,nq); } cout << ans; }

컴파일 시 표준 에러 (stderr) 메시지

cake3.cpp: In function 'int main()':
cake3.cpp:104:41: warning: unused variable 'cnt' [-Wunused-variable]
  104 |             for(int i=max(mid+m-1,optl),cnt=0;i<=optr;i++){
      |                                         ^~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...