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

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Aurora_U

谢谢你的鼓励,我会继续努力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值