이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#define pii pair<long long, long long>
#define x first
#define y second
using namespace std;
const int N = 2e5 + 10;
int n, m, ver[N];
pii cake[N];
vector<long long> t, coord;
vector<int> sz, L, R;
unordered_map<long long, int> mp;
long long ans[N], ret;
int newleaf( long long va, int ss ) {
t.emplace_back( va ), sz.emplace_back( ss ), L.emplace_back( -1 ), R.emplace_back( -1 );
return (int)t.size() - 1;
}
int newpar( int l, int r ) {
t.emplace_back( t[l] + t[r] ), sz.emplace_back( sz[l] + sz[r] );
L.emplace_back( l ), R.emplace_back( r );
return (int)t.size() - 1;
}
int get( int x ) {
mp[x]++;
return lower_bound( coord.begin(), coord.end(), x ) - coord.begin() + mp[x];
}
int build( int l = 1, int r = coord.size() ) {
if( l == r ) return newleaf( 0, 0 );
int mid = l + r >> 1;
return newpar( build( l, mid ), build( mid+1, r ) );
}
int update( int x, long long va, int p, int l = 1, int r = coord.size() ) {
if( l == r ) return newleaf( va, 1 );
int mid = l + r >> 1;
if( mid >= x ) return newpar( update( x, va, L[p], l, mid ), R[p] );
else return newpar( L[p], update( x, va, R[p], mid+1, r ) );
}
long long query( int a, int b, int x, int l = 1, int r = coord.size() ) {
if( x <= 0 ) return 0LL;
if( l == r ) return t[b] - t[a];
int mid = l + r >> 1;
if( sz[R[b]] - sz[R[a]] >= x ) return query( R[a], R[b], x, mid+1, r );
else return t[R[b]] - t[R[a]] + query( L[a], L[b], x - sz[R[b]] + sz[R[a]], l, mid );
}
void solve( int l, int r, int optl, int optr ) {
if( l > r ) return ;
int mid = l + r >> 1, idx = optl;
ans[mid] = -1e18;
for( int i = max( mid + m - 1, optl ) ; i <= optr ; i++ ) {
int now = query( ver[mid], ver[i-1], m-2 ) + cake[i].x + cake[mid].x - 2*cake[i].y + 2*cake[mid].y;
//printf("%d %d\n",i,now);
if( now > ans[mid] ) ans[mid] = now, idx = i;
}
//printf("%d %d %d %d %d %lld\n",l,mid,r,optl,optr,ans[mid]);
solve( l, mid-1, optl, idx ), solve( mid+1, r, idx, optr );
}
int main()
{
t.emplace_back( 0 ), sz.emplace_back( 0 ), R.emplace_back( 0 ), L.emplace_back( 0 );
scanf("%d %d",&n,&m);
for( int i = 1 ; i <= n ; i++ ) {
scanf("%lld %lld",&cake[i].x,&cake[i].y);
coord.emplace_back( cake[i].x );
}
sort( cake + 1, cake + 1 + n, [&]( const pii &a, const pii &b ) {
return a.y < b.y;
});
sort( coord.begin(), coord.end() );
ver[0] = build();
for( int i = 1 ; i <= n ; i++ ) ver[i] = update( get( cake[i].x ), cake[i].x, ver[i-1] );
solve( 1, n-m+1, 1, n );
for( int i = 1 ; i <= n-m+1 ; i++ ) ret = max( ret, ans[i] );
printf("%lld",ret);
return 0;
}
컴파일 시 표준 에러 (stderr) 메시지
cake3.cpp: In function 'int build(int, int)':
cake3.cpp:35:17: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
int mid = l + r >> 1;
~~^~~
cake3.cpp: In function 'int update(int, long long int, int, int, int)':
cake3.cpp:41:17: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
int mid = l + r >> 1;
~~^~~
cake3.cpp: In function 'long long int query(int, int, int, int, int)':
cake3.cpp:49:17: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
int mid = l + r >> 1;
~~^~~
cake3.cpp: In function 'void solve(int, int, int, int)':
cake3.cpp:56:17: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
int mid = l + r >> 1, idx = optl;
~~^~~
cake3.cpp: In function 'int main()':
cake3.cpp:70:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
scanf("%d %d",&n,&m);
~~~~~^~~~~~~~~~~~~~~
cake3.cpp:72:14: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
scanf("%lld %lld",&cake[i].x,&cake[i].y);
~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |