[CF191](Fools and Roads)

1541 단어
제목: 나무 한 그루 를 드 리 고 m 대 점 을 드 리 겠 습 니 다. 각 점 간 의 가장 짧 은 경 로 를 각 변 의 가중치 + 1 로 조작 이 완 료 된 후 각 변 의 가중치 를 구 합 니 다.
solution: 나무 에 차이 점 이 있 습 니 다.
나무 에 차이 점 이 있 는 판 자 는 다음 과 같 습 니 다. 차이 점 그룹 p, 경로 s - > t, p [s] +, p [t] +, p [lca (s, t)] -, p [fa [lca [(s, t)]] -;
그리고 한 점 의 하위 트 리 내 차이 점 의 합 은 이 점 을 덮어 쓰 는 횟수 입 니 다. 그러나 이 문 제 는 우리 에 게 변 을 처리 하 라 고 요구 합 니 다.
그러면 저희 가 두 가지 방법 이 있어 요.
하 나 는 한 변 에 대해 새로운 점 은 이 변 을 대표 하고 이 점 에서 변 으로 향 하 는 두 점 의 연결 변 이다.
폭력 적 이지 만 머리 가 없다.
다른 하 나 는 한 변 의 두 점 중 깊이 가 비교적 큰 점 으로 이 변 을 대표 하 는 것 이다.
그러나 이때 원래 의 차분 조작 은 냄비 에서 나온다. p [s] +, p [t] +, p [lca (s, t)] - 2 (스스로 이해) 로 바 꿔 야 한다.
코드 붙 이기 (첫 번 째 방법, 오로라 서 ST 표 LCA 구하 기)#include #include #include #include #include #define N 400050 using namespace std; vector G[N]; int n,m; int dfn[N],pos[N],lg[N],dep[N]; int id[N],ans[N]; int st[35][N],cnt=0,plu[N],fa[N]; void aux(int x,int ff) { dfn[++cnt]=x,pos[x]=cnt,fa[x]=ff; for(int i=0; i>1]+1; for(int i=1; i<=cnt; i++)st[0][i]=dfn[i]; for(int i=1; i<=lg[cnt]; i++) for(int r=1; r+(1<y)swap(x,y); int p=lg[y-x+1]; return mn(st[p][x],st[p][y-(1<
다음으로 전송:https://www.cnblogs.com/stepsys/p/10802586.html

좋은 웹페이지 즐겨찾기