[POJ 1155] TELE (树形dp)
题目链接:http://poj.org/problem?id=1155
题目大意:电视台要广播电视节目,要经过中转机构,到观众。从电视台到中转商到观众是一个树形结构,经过一条边需要支付成本。现在给你每两个节点之间传播的成本,给你每个观众会付的钱,问你电视台在不亏本的情况下最多能给多少个观众看节目。
这是我的第一道树形dp。。无耻的看了题解。。
设计状态:dp[u][i]代表以u为根的子树中有i个观众,能够得到的最大收入。
状态转移:dp[u][i] = max(dp[u][i],dp[u][i-j]+dp[v][j]-cost[u][v]);
用java写了一个版本。。总是RE,就不知道是为什么了。。
代码:
#include <cstdio>
#include <cmath>
#include <algorithm>
#include <cstring>
#include <vector>
using namespace std; const int MAX_N = ;
const int INF = ;
struct EDGE{
int to,cost;
int next;
};
EDGE edge[MAX_N<<];
int ptr,head[MAX_N];
int cost[MAX_N]; void init(){
memset(edge,-,sizeof(edge));
memset(head,-,sizeof(head));
ptr = ;
} void add_edge(int from,int to,int cost){
edge[ptr].to = to;
edge[ptr].cost = cost;
edge[ptr].next = head[from];
head[from] = ptr++;
} int N,M;
int dp[MAX_N][MAX_N];
bool vis[MAX_N];
int sum[MAX_N]; void DP(int u){
if( vis[u] ) return;
vis[u] = true; dp[u][] = ;
int tot = ; for(int i=head[u];~i;i=edge[i].next){
int v = edge[i].to;
if( !vis[v] ){
tot++;
DP( v );
sum[u] += sum[v];
}
} if( tot== ){
sum[u] = ;
dp[u][] = cost[u];
} else {
for(int k=head[u];~k;k=edge[k].next){
int v = edge[k].to;
for(int j=sum[u];j>=;--j){
for(int i=;i<=sum[v];i++){
if( j>=i && dp[u][j-i]!=-INF && dp[v][i]!=-INF){
dp[u][j] = max(dp[u][j],dp[u][j-i]+dp[v][i]-edge[k].cost);
}
}
}
}
}
} int main(){
while(scanf("%d%d",&N,&M)!=EOF){
init();
int k;
for(int i=;i<=N-M;i++){
scanf("%d",&k);
for(int j=;j<k;j++){
int a,c;
scanf("%d%d",&a,&c);
add_edge(i,a,c);
add_edge(a,i,c);
}
} for(int i=N-M+;i<=N;i++){
scanf("%d",&cost[i]);
} memset(vis,,sizeof(vis));
memset(sum,,sizeof(sum));
for(int i=;i<=N;i++){
for(int j=;j<=N;j++){
dp[i][j] = -INF;
}
}
DP();
for(int i=N;i>=;--i){
if( dp[][i] >= ) {
printf("%d\n",i);
break;
}
} }
return ;
}
[POJ 1155] TELE (树形dp)的更多相关文章
- POJ 1155 TELE 背包型树形DP 经典题
由电视台,中转站,和用户的电视组成的体系刚好是一棵树 n个节点,编号分别为1~n,1是电视台中心,2~n-m是中转站,n-m+1~n是用户,1为root 现在节点1准备转播一场比赛,已知从一个节点传送 ...
- Apple Tree POJ - 2486 (树形dp)
题目链接: D - 树形dp POJ - 2486 题目大意:一颗树,n个点(1-n),n-1条边,每个点上有一个权值,求从1出发,走V步,最多能遍历到的权值 学习网址:https://blog.c ...
- Anniversary party POJ - 2342 (树形DP)
题目链接: POJ - 2342 题目大意:给你n个人,然后每个人的重要性,以及两个人之间的附属关系,当上属选择的时候,他的下属不能选择,只要是两个人不互相冲突即可.然后问你以最高领导为起始点的关系 ...
- POJ 3107.Godfather 树形dp
Godfather Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 7536 Accepted: 2659 Descrip ...
- POJ 3342 (树形DP)
题意 :给出一些上下级关系,要求i和i的直接上级不能同时出现,现在选出一些人构成一个集合,问你这个集合里面的最大人数是都少,同时给出这个最大的人数的集合是否唯一. 思路:树形DP,dp[i][0],表 ...
- POJ 2342 (树形DP)
Anniversary party Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 3863 Accepted: 2172 ...
- POJ Anniversary party 树形DP
/* 树形dp: 给一颗树,要求一组节点,节点之间没有父子关系,并且使得所有的节点的权值和最大 对于每一个节点,我们有两种状态 dp[i][0]表示不选择节点i,以节点i为根的子树所能形成的节点集所能 ...
- poj 1155 TELE(树形DP)
TELE Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 4863 Accepted: 2673 Description ...
- poj 1155 TELE (树形背包dp)
本文出自 http://blog.csdn.net/shuangde800 题目链接: poj-1155 题意 某收费有线电视网计划转播一场重要的足球比赛.他们的转播网和用户终端构成一棵树状结构, ...
随机推荐
- 数字根(digital root)
来源:LeetCode 258 Add Dights Question:Given a non-negative integer num , repeatedly add all its digi ...
- Jquery ajax提交表单几种方法详解
[导读] 在jquery中ajax提交表单有post与get方式,在使用get方式时我们可以直接使用ajax 序列化表单$( 表单ID) serialize();就行了,下面我来介绍两个提交表单数据的 ...
- 每日学习心得:CustomValidator验证控件验证用户输入的字符长度、Linq 多字段分组统计、ASP.NET后台弹出confirm对话框,然后点击确定,执行一段代码
2013-9-15 1. CustomValidator验证控件验证用户输入的字符长度 在实际的开发中通常会遇到验证用户输入的字符长度的问题,通常的情况下,可以写一个js的脚本或者函数,在ASP ...
- [转]Hibernate重要规则总结
实体类的编写规则 l 实体类必须具备无参构造方法 l 实体类必须具备数据库标识 l 通常选用无业务意义的逻辑主键作为数据库标识,通常是int/long/Str ...
- [转]UOS 中的虚拟网络设备
随着网络技术,虚拟化技术的发展,越来越多的高级网络设备被加入了到了 Linux 中,这些设备在 UOS 中起到了广泛而关键的作用,包括 Open vSwitch.TAP 设备.Veth 设备等等,梳理 ...
- WPF性能提高--MSDN学习摘要
关于性能 一. 关于硬件加速 1.对于大多数图形硬件而言,大型图面是指达到 2048x2048 或 4096x4096 像素大小的图面. 二. 合理的布局 1.简单地说,布局是一个递归系统 ...
- fiddler Android下https抓包全攻略
fiddler Android下https抓包全攻略 fiddler的http.https的抓包功能非常强大,可非常便捷得对包进行断点跟踪和回放,但是普通的配置对于像招商银行.支付宝.陌陌这样的APP ...
- Tomcat无法启动:org.apache.catalina.LifecycleException: Failed to start component 问题解决
问题如下:需要使用到数据库mysql,于是将mysql-connector-java-5.1.30-bin.jar的数据库驱动复制到WEE-INF/lib目录下.点击运行,但是服务器无法启动. 控制台 ...
- 黄聪:PHP字符串操作(string替换、删除、截取、复制、连接、比较、查找、包含、大小写转换、切割成数组等)
一.字符串替换 str_replace("iwind", "kiki", "i love iwind, iwind said"); 将输出 ...
- Linux客户端、服务器、窗口管理器的关系
嵌入式linux中文站发现很多LINUX初学者在学习linux图形方面的知识时会遇到一些概念,如:X.X11.Xfree86.WM.KDE.GNOME.QT.QT/E.Qtopia.DirectFB. ...