树形dp(数字转换NOIP17提高模拟训练4)

本文通过分析NOIP2017提高组模拟训练第四题,探讨了如何利用树形动态规划(TreeDP)解决数字转换问题。通过对样例输入和输出的展示,解释了树形DP在解决此类问题时的思路和步骤。

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

如果一个数x的约数和(不包括它本身,下同)比它本身小,那么x可以变成它的约数和;如果对于某个y>x且y的约数和为x,那么x也可以变成y。例如,4可以变为3,1可以变为7。限定所有的数字变换在不超过n的正整数范围内进行,求不断进行数字变换且没有重复数字出现的最多变换步数。
输入一个正整数n。
输出最少需要花费的时间。

样例输入:

7

样例输出:

3
这是网上抄来的解析:如果x和y可以互相转化,就连接一条无向边,最后得到的图其实是一个森林,每棵树都是无根树,其实就是要求,整个森林中两个连通的点的最远距离(这里边权都是1),和在无根树中求两点最远距离是一样的,不过这题的特殊性,可以更方便点
对于任意一条边,必有x<y,在树中,x就应该为y的双亲(因为y的约数和是唯一的,但x可能是很多个数的约数和,这正好对应树的关系,双亲唯一,孩子不定)。而dp思想照样是找出每个节点到叶子的最大值m1和次大值m2,再两者相加的dp[rt],而整个树中的最大值,就是扫描全部节点,找到最大的dp[rt]
由于这题,每个节点的双亲是可以记录下来的,所以dp的时候不用递归,而写成递推式,直接从叶往上递推,为什么不能从根往下递推呢,这很容易理解,想想我们是怎么计算m1和m2的
还有一个重要的时候就是怎么找出约数和,数据比较大,应该尽量避免多余的判断,用筛法求约数和则是一个不错的方法
这是我的代码:
#include<bits/stdc++.h>
#define maxn 102930
usi
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值