#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;
}