Submission #1609283
Source Code Expand
#include<iostream>
#include<iomanip>
#include<math.h>
#include<vector>
#include<algorithm>
#include<set>
#include<map>
#include<queue>
#include<stack>
#include<string>
#define INF 1000000000ll
#define MOD 1000000007ll
#define EPS 1e-10
#define REP(i,m) for(long long i=0; i<m; ++i)
#define FOR(i,n,m) for(long long i=n; i<m; ++i)
#define DUMP(n,a) for(long long dump=0; dump<n; ++dump) { cout<<a[dump]; if(dump!=n-1) cout<<" "; else cout<<endl; }
#define ALL(v) v.begin(),v.end()
#define pb push_back
using namespace std;
typedef long long ll;
typedef pair<ll, ll> P;
typedef long double ld;
vector<ll> depth;
vector<vector<ll>> par(21);
void dfs(ll roc,ll d,ll p,vector<vector<ll>>& adj) {
depth[roc]=d;
if(p!=-1) par[0][roc]=p;
REP(i,adj[roc].size()) {
if(adj[roc][i]==p) continue;
dfs(adj[roc][i],d+1,roc,adj);
}
}
int main() {
cin.tie(0);
ios::sync_with_stdio(false);
ll n;
cin>>n;
vector<vector<ll>> adj(n);
depth.resize(n);
REP(i,21) par[i].resize(n);
REP(i,n-1) {
ll x,y;
cin>>x>>y;
--x;--y;
adj[x].pb(y);
adj[y].pb(x);
}
dfs(0,0,-1,adj);
FOR(i,1,21) {
REP(j,n) {
if(depth[j]>=(1<<i)) {
par[i][j]=par[i-1][par[i-1][j]];
}
}
}
ll q;
cin>>q;
REP(i,q) {
ll a,b;
cin>>a>>b;
--a;--b;
if(depth[a]<depth[b]) swap(a,b);
ll lb=-1,ub=depth[b];
while(ub-lb>1) {
ll mid=(lb+ub)/2;
ll _a=a;
ll _b=b;
int c=0;
for(ll ca=depth[a]-depth[b]+mid; ca>0; ca/=2) {
if(ca%2==1) _a=par[c][_a];
++c;
}
c=0;
for(ll cb=mid; cb>0; cb/=2) {
if(cb%2==1) _b=par[c][_b];
++c;
}
if(_a!=_b) lb=mid;
else ub=mid;
}
++lb;
cout<<(2*lb+(depth[a]-depth[b]))+1<<endl;
}
}
Submission Info
Submission Time |
|
Task |
D - 閉路 |
User |
gazelle |
Language |
C++14 (GCC 5.4.1) |
Score |
100 |
Code Size |
1741 Byte |
Status |
AC |
Exec Time |
323 ms |
Memory |
29952 KB |
Judge Result
Set Name |
Sample |
Subtask1 |
Subtask2 |
Score / Max Score |
0 / 0 |
30 / 30 |
70 / 70 |
Status |
|
|
|
Set Name |
Test Cases |
Sample |
subtask0_sample01.txt, subtask0_sample02.txt, subtask0_sample03.txt |
Subtask1 |
subtask1_01.txt, subtask1_02.txt, subtask1_03.txt, subtask1_04.txt, subtask1_05.txt, subtask1_06.txt, subtask1_07.txt, subtask1_08.txt, subtask1_09.txt, subtask1_10.txt, subtask1_11.txt, subtask1_12.txt |
Subtask2 |
subtask0_sample01.txt, subtask0_sample02.txt, subtask0_sample03.txt, subtask1_01.txt, subtask1_02.txt, subtask1_03.txt, subtask1_04.txt, subtask1_05.txt, subtask1_06.txt, subtask1_07.txt, subtask1_08.txt, subtask1_09.txt, subtask1_10.txt, subtask1_11.txt, subtask1_12.txt, subtask2_01.txt, subtask2_02.txt, subtask2_03.txt, subtask2_04.txt, subtask2_05.txt, subtask2_06.txt, subtask2_07.txt, subtask2_08.txt, subtask2_09.txt, subtask2_10.txt, subtask2_11.txt, subtask2_12.txt |
Case Name |
Status |
Exec Time |
Memory |
subtask0_sample01.txt |
AC |
1 ms |
256 KB |
subtask0_sample02.txt |
AC |
1 ms |
256 KB |
subtask0_sample03.txt |
AC |
1 ms |
256 KB |
subtask1_01.txt |
AC |
41 ms |
29184 KB |
subtask1_02.txt |
AC |
41 ms |
29184 KB |
subtask1_03.txt |
AC |
1 ms |
256 KB |
subtask1_04.txt |
AC |
1 ms |
256 KB |
subtask1_05.txt |
AC |
2 ms |
512 KB |
subtask1_06.txt |
AC |
1 ms |
512 KB |
subtask1_07.txt |
AC |
50 ms |
23552 KB |
subtask1_08.txt |
AC |
50 ms |
23552 KB |
subtask1_09.txt |
AC |
52 ms |
23552 KB |
subtask1_10.txt |
AC |
52 ms |
23552 KB |
subtask1_11.txt |
AC |
52 ms |
23552 KB |
subtask1_12.txt |
AC |
52 ms |
23552 KB |
subtask2_01.txt |
AC |
202 ms |
29952 KB |
subtask2_02.txt |
AC |
233 ms |
29824 KB |
subtask2_03.txt |
AC |
159 ms |
512 KB |
subtask2_04.txt |
AC |
166 ms |
512 KB |
subtask2_05.txt |
AC |
187 ms |
768 KB |
subtask2_06.txt |
AC |
199 ms |
896 KB |
subtask2_07.txt |
AC |
239 ms |
23936 KB |
subtask2_08.txt |
AC |
245 ms |
23808 KB |
subtask2_09.txt |
AC |
294 ms |
23808 KB |
subtask2_10.txt |
AC |
313 ms |
23936 KB |
subtask2_11.txt |
AC |
323 ms |
23936 KB |
subtask2_12.txt |
AC |
316 ms |
23936 KB |