# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
465858 | CaroLinda | Birthday gift (IZhO18_treearray) | C++14 | 4081 ms | 64196 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
const int MAXN = 2e5+10 ;
const int LOG = 20 ;
using namespace std ;
using namespace __gnu_pbds;
#define ordered_set tree<int, null_type,less<int>, rb_tree_tag,tree_order_statistics_node_update>
int N , M , Q ;
int arr[MAXN ] ;
int dp[LOG][MAXN] , lvl[MAXN] ;
vector<int> adj[MAXN] ;
ordered_set o_set[MAXN] , norma[MAXN] ;
void dfs(int x)
{
for(int i = 1 ; dp[i-1][x] != -1 ; i++ )
dp[i][x] = dp[i-1][ dp[i-1][x] ] ;
for(auto e : adj[x] )
{
if(e == dp[0][x]) continue ;
dp[0][e] = x ;
lvl[e] = lvl[x]+1 ;
dfs(e) ;
}
}
int getLca(int x, int y)
{
if(lvl[x] < lvl[y]) swap(x,y) ;
for(int i = LOG-1 ; i >= 0 ; i-- )
if( dp[i][x] != -1 && lvl[dp[i][x]] >= lvl[y] )
x = dp[i][x] ;
if(x == y ) return x ;
for(int i = LOG-1 ; i >= 0 ; i-- )
if(dp[i][x] != -1 && dp[i][x] != dp[i][y])
{
x = dp[i][x] ;
y = dp[i][y] ;
}
return dp[0][x] ;
}
void op(int idx, int type )
{
int L ;
if(type == -1) norma[ arr[idx] ].erase( norma[ arr[idx] ].find(idx) ) ;
else norma[arr[idx]].insert(idx) ;
if( idx > 1 )
{
L = getLca(arr[idx-1] , arr[idx]) ;
if(type == -1) o_set[L].erase( o_set[L].find(idx-1) ) ;
else o_set[L].insert(idx-1) ;
}
if(idx+1 <= M)
{
L = getLca(arr[idx] , arr[idx+1]) ;
if(type == -1) o_set[L].erase( o_set[L].find(idx) ) ;
else o_set[L].insert(idx) ;
}
}
int main()
{
memset(dp, -1, sizeof dp );
cin >> N >> M >> Q ;
for(int i = 0 , x , y; i < N-1 ; i++ )
{
scanf("%d %d", &x, &y ) ;
adj[x].push_back(y) ;
adj[y].push_back(x) ;
}
dfs(1) ;
for(int i = 1 ; i <= M ; i++ ) scanf("%d", &arr[i]) ;
while(Q--)
{
int t , L , R , v , pos ;
scanf("%d", &t ) ;
if(t == 1)
{
scanf("%d %d", &pos, &v ) ;
arr[pos] = v ;
}
else
{
scanf("%d %d %d", &L, &R, &v ) ;
int l = -1 , r = -1 ;
for(int i = L ; i <= R ; i++ )
if(arr[i] == v ) l = r = i ;
for(int i = L ; i < R ; i++ )
{
if(getLca(arr[i] , arr[i+1]) == v ) l = i , r = i+1 ;
}
printf("%d %d\n" , l , r ) ;
}
}
}
컴파일 시 표준 에러 (stderr) 메시지
# | 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... |