【HNOI 2008 明明的烦恼】树的prufer编码

介绍Prüfer编码方法,一种将带标号的树映射为序列的技术,解释了n个点的树为何有n^(n-2)种,并提供解决特定问题的算法思路。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

有一种叫树的prufer编码的神奇东西能将一棵点带标号的树一一对应地映射成一个长度为N-2的序列,方法如下:

每次取出未被删除的标号最小的度为1的点,将这个点相邻的那个点加入序列,同时删除这个点,直到整棵树只剩两个点

还原的话,只要从前往后扫这个序列a,将a[i]与序列a中i之后没出现的标号最小的且没被标记过点相连,同时将那个点标记一下,直到最后剩两个没标记的点,将他们相连即可

这个编码方法也顺便解释了n个点的树有n^(n-2)个

回到这道题,一个点的度数就是它在a序列中出现次数+1,所以这个问题就很容易解决了

已经确定的点就用排列先排好,没确定的点就可以在剩下的位置里随便填

最后要高精度

代码:

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值