poj 2486 树形DP
来源:互联网 发布:dede目录权限优化工具 编辑:程序博客网 时间:2024/06/04 17:57
见注释。
AC代码如下:
#include <iostream>#include <cstdio>#include <cstring>#include <vector>using namespace std;int N, K;int dp[2][101][201];vector<int> edge[200];bool visit[101];int apple[101];inline int max( int a, int b ){return ( a > b ? a : b );}void DFS( int n ){if( visit[n] ){return;}visit[n] = true;for( int i = 0; i <= K; i++ ){//当不往下走时dp[0][n][i] = dp[1][n][i] = apple[n];}for( int i = 0; i < edge[n].size(); i++ ){//继续往下走 DPint t = edge[n][i];if( visit[t] ){continue;}DFS( t );for( int j = K; j >= 0; j-- ){for( int k = 0; k <= j; k++ ){dp[0][n][j+2] = max( dp[0][n][j+2], dp[0][n][j-k] + dp[0][t][k] );//在t中走k步获得的最大再回到ndp[1][n][j+1] = max( dp[1][n][j+1], dp[0][n][j-k] + dp[1][t][k] );//在t中走k步或得最大,留在t的子树或tdp[1][n][j+2] = max( dp[1][n][j+2], dp[0][t][k] + dp[1][n][j-k] );//在t中走k步或得最大,再回到n,再留在n的子树或n}}}}int main(){while( scanf( "%d%d", &N, &K ) != EOF ){memset( dp, 0, sizeof( dp ) );memset( visit, false, sizeof( visit ) );for( int i = 0; i < 200; i++ ){edge[i].clear();}for( int i = 1; i <= N; i++ ){cin >> apple[i];}for( int i = 1; i < N; i++ ){int temp1, temp2;cin >> temp1 >> temp2;edge[temp1].push_back( temp2 );edge[temp2].push_back( temp1 );}DFS(1);cout << dp[1][1][K] << endl;}return 0;}
- poj 2486 树形dp
- poj 2486 树形DP
- poj 2486 树形dp
- poj 2486 树形DP
- poj-2486-树形dp
- poj 2486( 树形dp)
- POJ 2486 树形DP
- poj 2486 树形dp
- poj 2486(树形dp)
- POJ 2486 树形dp
- poj 2486 树形dp
- POJ-2486-树形dp
- poj 2486 树形dp
- poj 2486 (树形DP)
- POJ 2486 经典树形dp
- POJ 2486 树形DP+背包
- POJ 2486 Apple Tree 树形DP
- POJ 2486 Apple Tree 树形dp
- android完全退出应用
- 使用别人的LocalDB制作本地库
- 【ASM的学习】asm官方手册学习心得01
- cuda 任意维度的矩阵相乘
- 汉诺塔问题深刻而简单的理解
- poj 2486 树形DP
- android Service(一) activity启动Service方式一:startService()
- LinearLayout中weight的学习
- 处理消息
- 某个工具从以下位置返回了错误代码: "正在执行预链接事件
- java和c的区别
- 易友姓名测试软件发布
- Micaps3.2二次开发实例教程-3
- 总结创建窗口全过程