이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "teams.h"
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef pair<int, int> pii;
typedef pair<ll, ll> pll;
const int MAXN = 5e5;
struct Point
{
int X, Y;
bool operator < (const Point &p) const { return pii(X, Y)<pii(p.X, p.Y); }
};
struct Node
{
int val;
Node *lc, *rc;
Node() : lc(NULL), rc(NULL), val(0) {}
};
void makeTree(Node *node, int tl, int tr)
{
if(tl==tr) return;
int mid=tl+tr>>1;
node->lc=new Node();
node->rc=new Node();
makeTree(node->lc, tl, mid);
makeTree(node->rc, mid+1, tr);
}
Node *addTree(Node *node, int tl, int tr, int pos)
{
if(pos<tl || tr<pos) return node;
Node *ret=new Node();
if(tl==tr)
{
ret->val=node->val+1;
return ret;
}
int mid=tl+tr>>1;
ret->lc=addTree(node->lc, tl, mid, pos);
ret->rc=addTree(node->rc, mid+1, tr, pos);
ret->val=ret->lc->val+ret->rc->val;
return ret;
}
int query(Node *nodel, Node *noder, int tl, int tr, int l, int r)
{
if(l<=tl && tr<=r) return noder->val-nodel->val;
if(r<tl || tr<l) return 0;
int mid=tl+tr>>1;
return query(nodel->lc, noder->lc, tl, mid, l, r)+query(nodel->rc, noder->rc, mid+1, tr, l, r);
}
Node *tree[MAXN+10];
int N;
Point A[MAXN+10], B[MAXN+10];
int xval[MAXN+10], yval[MAXN+10];
int xcomp[MAXN+10], ycomp[MAXN+10];
int query(int xl, int xr, int yl, int yr)
{
int x=query(tree[xl], tree[xr], 0, N+1, yl, yr);
printf("%d %d %d %d : %d\n", xl, xr, yl, yr, x);
return x;
}
int M, K[MAXN+10];
void init(int _N, int _A[], int _B[])
{
int i, j;
N=_N; for(i=1; i<=N; i++) A[i]={_A[i-1], _B[i-1]};
sort(A+1, A+N+1);
vector<pii> V;
for(i=1; i<=N; i++) V.push_back({A[i].Y, i});
sort(V.begin(), V.end());
for(i=0; i<V.size(); i++) B[V[i].second].Y=i+1;
for(i=1; i<=N; i++) B[i].X=i;
tree[0]=new Node();
makeTree(tree[0], 0, N+1);
for(i=1; i<=N; i++) tree[i]=addTree(tree[i-1], 0, N+1, B[i].Y);
for(i=1; i<=N; i++) xval[B[i].X]=A[i].X;
for(i=1; i<=N; i++) yval[B[i].Y]=A[i].Y;
for(i=1; i<=N; i++) xcomp[i]=upper_bound(xval+1, xval+N+1, i)-xval-1;
for(i=1; i<=N; i++) ycomp[i]=lower_bound(yval+1, yval+N+1, i)-yval;
for(i=1; i<=N; i++) printf("%d ", xcomp[i]); printf("\n");
for(i=1; i<=N; i++) printf("%d ", ycomp[i]); printf("\n");
}
int can(int _M, int _K[])
{
int i, j;
M=_M; for(i=1; i<=M; i++) K[i]=_K[i-1];
sort(K+1, K+M+1);
vector<Point> S;
S.push_back({0, N+1});
for(i=1; i<=M; i++)
{
int todo=K[i];
Point now={xcomp[K[i]], ycomp[K[i]]};
while(!S.empty() && S.back().Y<now.Y) S.pop_back();
while(1)
{
printf("!%d %d\n", now.X, now.Y);
if(S.empty()) return 0;
Point T=S.back();
int lo=now.Y-1, hi=T.Y;
while(lo+1<hi)
{
int mid=lo+hi>>1;
int p=query(T.X, now.X, now.Y, mid);
if(p<todo) lo=mid;
else hi=mid;
}
todo-=query(T.X, now.X, now.Y, hi);
if(todo==0)
{
if(lo==T.Y) S.pop_back();
printf("WTF %d\n", hi);
S.push_back({now.X, hi});
break;
}
now.Y=T.Y+1;
S.pop_back();
}
for(auto it : S) printf("%d %d\n", it.X, it.Y);
printf("\n");
}
return 1;
}
컴파일 시 표준 에러 (stderr) 메시지
teams.cpp: In constructor 'Node::Node()':
teams.cpp:20:13: warning: 'Node::rc' will be initialized after [-Wreorder]
Node *lc, *rc;
^~
teams.cpp:19:6: warning: 'int Node::val' [-Wreorder]
int val;
^~~
teams.cpp:21:2: warning: when initialized here [-Wreorder]
Node() : lc(NULL), rc(NULL), val(0) {}
^~~~
teams.cpp: In function 'void makeTree(Node*, int, int)':
teams.cpp:27:12: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
int mid=tl+tr>>1;
~~^~~
teams.cpp: In function 'Node* addTree(Node*, int, int, int)':
teams.cpp:43:12: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
int mid=tl+tr>>1;
~~^~~
teams.cpp: In function 'int query(Node*, Node*, int, int, int, int)':
teams.cpp:54:12: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
int mid=tl+tr>>1;
~~^~~
teams.cpp: In function 'void init(int, int*, int*)':
teams.cpp:84:12: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for(i=0; i<V.size(); i++) B[V[i].second].Y=i+1;
~^~~~~~~~~
teams.cpp:93:68: warning: conversion to 'int' from 'long int' may alter its value [-Wconversion]
for(i=1; i<=N; i++) xcomp[i]=upper_bound(xval+1, xval+N+1, i)-xval-1;
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~
teams.cpp:94:63: warning: conversion to 'int' from 'long int' may alter its value [-Wconversion]
for(i=1; i<=N; i++) ycomp[i]=lower_bound(yval+1, yval+N+1, i)-yval;
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~
teams.cpp:96:2: warning: this 'for' clause does not guard... [-Wmisleading-indentation]
for(i=1; i<=N; i++) printf("%d ", xcomp[i]); printf("\n");
^~~
teams.cpp:96:47: note: ...this statement, but the latter is misleadingly indented as if it were guarded by the 'for'
for(i=1; i<=N; i++) printf("%d ", xcomp[i]); printf("\n");
^~~~~~
teams.cpp:97:2: warning: this 'for' clause does not guard... [-Wmisleading-indentation]
for(i=1; i<=N; i++) printf("%d ", ycomp[i]); printf("\n");
^~~
teams.cpp:97:47: note: ...this statement, but the latter is misleadingly indented as if it were guarded by the 'for'
for(i=1; i<=N; i++) printf("%d ", ycomp[i]); printf("\n");
^~~~~~
teams.cpp:77:9: warning: unused variable 'j' [-Wunused-variable]
int i, j;
^
teams.cpp: In function 'int can(int, int*)':
teams.cpp:121:15: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
int mid=lo+hi>>1;
~~^~~
teams.cpp:102:9: warning: unused variable 'j' [-Wunused-variable]
int i, j;
^
# | 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... |