AcWing 树形DP相关问题 1075. 数字转换

本文详细探讨了AcWing在线判题平台上的第1075题——数字转换,该题目涉及树形动态规划(DP)的运用。文章通过实例解析和代码实现,帮助读者理解如何解决这类问题,提升算法思维能力。
摘要由CSDN通过智能技术生成
import sys
sys.stdin = open('data.txt', 'r')

'''
树形DP, 树的最长路径的应用, 求一个森林里面所有树的最长路径的最大值
'''

N = int(input())

# 先求所有值的约数
factor = {}
for i in range(1, N+1):
    for j in range(2, N // i + 1):  # 约数不能是自己,所以从2开始枚举,如果约数可以是自己,从1开始枚举
        if i*j not in factor:
            factor[i*j] = []
        factor[i*j].append(i)

link = {}
all_roots = set()
for x in factor:
    y = sum(factor[x])
    if y < x:
        if y not in link:
            link[y] = []
        link[y].append(x)
        if y not in all_roots:
            all_roots.add(y)
        if x in all_roots:
            all_roots.remove(x)

ans = [0]  # 定义单独一个点也是有路径的,路径长度是1, 全局最大值就初始化为1

def dfs(root, prev=None):
    # 最大值和次大值
    max1, max2 = 0, 0 # 最大值和次大值初始值设置为0, 可以直接避免掉负边带来的负面影响,默认可以看做每个节点都连接了无数个隐性的空节点,且边全权为0

    if root in link:
        for child in link[root]:
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值