poj 2486 树形DP n选m连续路径
题目连接:http://acm.hust.edu.cn/vjudge/problem/18071
资料连接:
http://blog.csdn.net/woshi250hua/article/details/7648798
http://blog.csdn.net/libin56842/article/details/10101807
这道题思路是这样的。

以这张图为例,以往的n选m题目,只要根节点选了,子树可以直接选,没有代价。所以可以直接dp[fa][j] = max(dp[fa][j],dp[fa][j-k]+dp[son][k])
但这题不一样,选了AB不代表你可以直接选C,需要按照一定的路径来,所以上面的就不适用了。那么这个问题如何解决?
我们可以这样想,就拿上图来说,以A点为研究对象时可以走的路有哪些情况

有四种:往左,往右,往左转一圈回来往右,往右转一圈回来往左
这四种情况其实包含两类动作,一类是往下搜索,一类是往下搜索然后回到原点。
这样状态就出来了,比起原本的我们要加一个状态,要记录回到原点的状态
dp[rt][j][0]表示回到原点,dp[son][j][1]表示不回原点
状态转移方程:
先维护回原点的状态
dp[rt][j][0] = max(dp[rt][j][0],dp[rt][j-k][0]+dp[son][k-2][0])
再分别维护左边回原点到右边
dp[rt][j][1] = max(dp[rt][j][1],dp[rt][j-k][0]+dp[son][k-1][1])
右边回原点到左边
dp[rt][j][1] = max(dp[rt][j][1],dp[rt][j-k][1]+dp[son][k-2][0])
#include <iostream>
#include <string>
#include <cstring>
#include <cstdlib>
#include <cstdio>
#include <cmath>
#include <algorithm>
#include <stack>
#include <queue>
#include <cctype>
#include <vector>
#include <iterator>
#include <set>
#include <map>
#include <sstream>
using namespace std; #define mem(a,b) memset(a,b,sizeof(a))
#define pf printf
#define sf scanf
#define spf sprintf
#define pb push_back
#define debug printf("!\n")
#define MAXN 200+5
#define MAX(a,b) a>b?a:b
#define blank pf("\n")
#define LL long long
#define ALL(x) x.begin(),x.end()
#define INS(x) inserter(x,x.begin())
#define pqueue priority_queue
#define INF 0x3f3f3f3f int n,m; struct node{int y,val,next;}tree[MAXN<<]; int head[MAXN],vis[MAXN],ptr=,val[MAXN],dp[MAXN][MAXN][]; void init()
{
mem(head,-);
mem(vis,);
mem(dp,);
ptr=;
}
void add(int x,int y)
{
tree[ptr].y = y;
tree[ptr].next = head[x];
head[x] = ptr++;
} void dfs(int rt)
{
vis[rt]=;
for(int i=;i<=m;i++) dp[rt][i][] = dp[rt][i][] = val[rt];
for(int i = head[rt];i!=-;i=tree[i].next)
{
int y = tree[i].y;
if(vis[y]) continue;
dfs(y); //pf("y%d\n",y);
for(int j=m;j>=;j--)
{
for(int k=;k<=j;k++)
{
dp[rt][j+][] = max(dp[rt][j+][],dp[rt][j-k][]+dp[y][k][]);
dp[rt][j+][] = max(dp[rt][j+][],dp[rt][j-k][]+dp[y][k][]);
dp[rt][j+][] = max(dp[rt][j+][],dp[rt][j-k][]+dp[y][k][]);
//pf("v%d %d %d %d %d\n",j+2,k,dp[rt][j+2][0],dp[rt][j+2][1],dp[rt][j+1][1]);
}
}
}
} int main()
{
int i,j,k;
while(~sf("%d%d",&n,&m))
{
init();
for(i=;i<=n;i++) sf("%d",&val[i]); for(i=;i<n;i++)
{
int x,y;
sf("%d%d",&x,&y);
add(x,y);
add(y,x);
}
dfs();
pf("%d\n",dp[][m][]);
}
}
/*
7 5
0 5 7 2 15 9 10
1 2
1 3
2 4
2 5
3 6
3 7
*/
poj 2486 树形DP n选m连续路径的更多相关文章
- poj 2486( 树形dp)
题目链接:http://poj.org/problem?id=2486 思路:经典的树形dp,想了好久的状态转移.dp[i][j][0]表示从i出发走了j步最后没有回到i,dp[i][j][1]表示从 ...
- Fire (poj 2152 树形dp)
Fire (poj 2152 树形dp) 给定一棵n个结点的树(1<n<=1000).现在要选择某些点,使得整棵树都被覆盖到.当选择第i个点的时候,可以覆盖和它距离在d[i]之内的结点,同 ...
- poj 1463(树形dp)
题目链接:http://poj.org/problem?id=1463 思路:简单树形dp,如果不选父亲节点,则他的所有的儿子节点都必须选,如果选择了父亲节点,则儿子节点可选,可不选,取较小者. #i ...
- poj 3140(树形dp)
题目链接:http://poj.org/problem?id=3140 思路:简单树形dp题,dp[u]表示以u为根的子树的人数和. #include<iostream> #include ...
- poj 3345 树形DP 附属关系+输入输出(好题)
题目连接:http://acm.hust.edu.cn/vjudge/problem/17665 参考资料:http://blog.csdn.net/woshi250hua/article/detai ...
- POJ 1155 树形DP
题意:电视台发送信号给很多用户,每个用户有愿意出的钱,电视台经过的路线都有一定费用,求电视台不损失的情况下最多给多少用户发送信号. 转自:http://www.cnblogs.com/andre050 ...
- POJ 3342 树形DP+Hash
这是很久很久以前做的一道题,可惜当时WA了一页以后放弃了. 今天我又重新捡了起来.(哈哈1A了) 题意: 没有上司的舞会+判重 思路: hash一下+树形DP 题目中给的人名hash到数字,再进行运算 ...
- Strategic game(POJ 1463 树形DP)
Strategic game Time Limit: 2000MS Memory Limit: 10000K Total Submissions: 7490 Accepted: 3483 De ...
- POJ 2342 树形DP入门题
有一个大学的庆典晚会,想邀请一些在大学任职的人来參加,每一个人有自己的搞笑值,可是如今遇到一个问题就是假设两个人之间有直接的上下级关系,那么他们中仅仅能有一个来參加,求请来一部分人之后,搞笑值的最大是 ...
随机推荐
- AB二进制
Description 若将一个正整数化为二进制数,在此二进制数中,我们将数字1的个数多于数字0的个数的这类二进制数称为A类数,否则就称其为B类数. 例如: (13)10=(1101)2 ...
- 大众点评CAT开源监控系统剖析
参考文档: 大众点评的实时监控系统分析(一) CAT_source_analyze 透过CAT,来看分布式实时监控系统的设计与实现 深度剖析开源分布式监控CAT [分布式监控CAT] Client端源 ...
- SpringBoot浏览器直接访问html
在resources文件夹或与其并列的文件夹下建立public文件夹,在public文件夹下的html文件可以通过浏览器中输入文件+后缀名的方式直接访问的. 一.public文件夹,就相当于在ecl ...
- 配置vuex并使用
配置vuex并使用 安装vuex: npm install --save-dev vuex 在src目录下创建store文件夹 store文件夹下文件 index.js,state.js,getter ...
- SysPeek打不开解决方法
SysPeek 是Linux平台下一款简洁小巧的系统状态指示软件,可实时显示 CPU.Memory.Swap.硬盘和网络使用情况.然而最近却使用不了,打不开.无论点击图标或者是终端打开,都不显示.看错 ...
- 使用Tensorflow object detection API——环境搭建与测试
[软件环境搭建] 操作系统:windows 10 64位 内存:8G CPU:I7-6700 Tensorflow: 1.4 Python:3.5 Anaconda3 (64-bit) 以上环境搭建请 ...
- maven部署Tomcat(出现空白页面,最终解决)
- docker搭建数据库主从复制
首先需要安装docker镜像: docker pull mysql:5.7 由于需要启动数据库才可以进入数据修改my.cnf文件,可以选择安装vi命令,也可以选择挂在 在此选择是挂载的方法进行安装: ...
- FPGA基础学习(1) -- FFT IP核(Quartus)
为了突出重点,仅对I/O数据流为steaming的情况作简要说明,以便快速上手,有关FFT ip核模型及每种设置详细介绍请参考官方手册FFT MegaCore Function User Guide. ...
- 【2014年百度之星资格赛1001】Energy Conversion
Problem Description 魔法师百小度也有遇到难题的时候—— 现在,百小度正在一个古老的石门面前,石门上有一段古老的魔法文字,读懂这种魔法文字需要耗费大量的能量和大量的脑力. 过了许久, ...