记录编号 304343 评测结果 AAAAAAAAAA
题目名称 距离 最终得分 100
用户昵称 Gravatariortheir 是否通过 通过
代码语言 C++ 运行时间 0.880 s
提交时间 2016-09-08 09:55:57 内存使用 0.73 MiB
显示代码纯文本
#include<iostream>
#include<cstdio>
#include<vector>

#define pb push_back

using namespace std;

const int maxn=10000+100;
const int maxm=20000+100;

int n;
int m;
int a;
int b;
int w;
int kount1=1;
int kount2=1;
int head[maxn];
int head1[maxn];
int father[maxn];
int rank[maxn];
int u[maxm];
int v[maxm];

int vis[maxn];
int dis[maxn];

int lca[maxm];

struct T1
{
	int to;
	int next;
	int w;
}A1[2*maxn];

inline void adde(int a,int b,int w)
{
	A1[++kount1].next=head[a];
	A1[kount1].to=b;
	A1[kount1].w=w;
	head[a]=kount1;
}

struct T2
{
	int to;
	int next;
	int w;
}A2[2*maxm];

inline void addq(int a,int b,int w)
{
	A2[++kount2].next=head1[a];
	A2[kount2].to=b;
	A2[kount2].w=w;
	head1[a]=kount2;
}

inline int find(int x)
{
	if(father[x]!=x)
	{
		father[x]=find(father[x]);
	}
	return father[x];
}

inline void unionn(int x,int y)
{
	father[x]=y;
}

inline void tarjan(int x)
{
	vis[x]=1;
	for(int i=head[x];i;i=A1[i].next)
	{
		if(!vis[A1[i].to])
		{
			dis[A1[i].to]=dis[x]+A1[i].w;
			tarjan(A1[i].to);
			unionn(A1[i].to,x);
		}
	}
	vis[x]=2;
	for(int i=head1[x];i;i=A2[i].next)
	{
		if(vis[A2[i].to]==2)
		{
			lca[A2[i].w]=find(A2[i].to);
		}
	}
}

int main()
{
	freopen("distance.in","r",stdin);
	freopen("distance.out","w",stdout);
	scanf("%d%d",&n,&m);
	for(int i=1;i<=n;++i)
	{
		father[i]=i;
	}
	for(int i=1;i<n;++i)
	{
		scanf("%d%d%d",&a,&b,&w);
		adde(a,b,w);
		adde(b,a,w);
	}
	for(int i=1;i<=m;++i)
	{
		scanf("%d%d",&u[i],&v[i]);
		addq(u[i],v[i],i);
		addq(v[i],u[i],i);
	}
	tarjan(1);
	for(int i=1;i<=m;++i)
	{
		cout<<dis[v[i]]+dis[u[i]]-dis[lca[i]]*2<<endl;
	}
	return 0;
}