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
AC × 3
AC × 12
AC × 27
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