#1947 : 推断上下级(hiho coder)

#1947 : 推断上下级

时间限制:10000ms

单点时限:1000ms

内存限制:256MB

描述

H公司包括CEO在内,一共有N名员工,编号1~N,其中CEO的编号是1。除了CEO之外,其他员工都有唯一一名直接上司,形成了一种树形的上下级关系。

现在小Hi知道H公司所有的上下级关系,一共M对。换句话说,只要两名员工A和B之间存在上下级关系(直接或者间接),那么A和B一定在这M对关系之中。  

请你帮小Hi推断出每个人的直接上级是谁。

输入

第一行包含两个整数N和M。  

以下M行,每行包含两个整数Ai和Bi,代表Ai是Bi的上级。  

2 <= N <= 1000  

1 <= M <= 499500

输出

输出N行,其中第i行包含一个整数Pi,代表i号员工的上级。(对CEO输出0)

样例输入

3 2
1 2
1 3

样例输出

0
1
1

思路:关键需要解决对于每组给出的上下级关系,他们是直接关系,还是间接关系是需要解决的 ,我想的是将所给的上级进行从小到大排序,不断的更新上级,最后的那个一定是直接上级。如果用并查集去做,需要增加约束条件,不能直接用模板。

代码如下:

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
ll n,m,ai,bi,a[1005];
struct node{
	ll x;
	ll y;
};
bool cmp(const node& a,const node&b)
{
	return a.x<b.x;
}
node g[500000];
int main()
{
	cin>>n>>m;
	for(ll i=0;i<m;i++)
	{
		scanf("%lld%lld",&g[i].x,&g[i].y);
	}
	sort(g,g+m,cmp);
	for(ll i=0;i<m;i++)
	{
		a[g[i].y]=g[i].x;
	}
	cout<<"0"<<endl;
	for(int j=2;j<=n;j++)
	{
		printf("%lld\n",a[j]);
	}
	return 0;
}

猜你喜欢

转载自blog.csdn.net/xyqqwer/article/details/88976345