题意:给定n门课程,某些课程有1门先行课,必须先修了先行课才可以选这门课,选择m门课,每门课有学分,求可以获得的最大学分数。
思路:首先建树,题目给出了0号就是虚根,所以可以直接建。
1、这里用链式前向星建图
2、dp[rt][m]:以rt为根的树,保留m个节点状态最优解,叶子节点就是边界,叶->根,采取dfs回溯转移,dp[0][m+1]就是答案,0是虚根所以+1
转移方程:dp[i][j]=max(dp[i][j],dp[child][a]+dp[i][j-a]) 枚举每个孩子 对每个孩子枚举a
时间复杂度为O(n³)
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<stdlib.h>
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<stdlib.h>
#include<string.h>
#include<string>
#include<vector>
#include<stack>
#include<queue>
#include<map>
#include<math.h>
#