wikioi 1163 访问艺术馆 树形dp
来源:互联网 发布:网络黄金egd未来城app 编辑:程序博客网 时间:2024/04/30 13:03
递归建树,由题知该树是一棵二叉树,且除根节点外其他点的度为0或2。
dp[i][j]表示来到第i个走廊(还未走过这条走廊)还剩下j时间,能拿到最大的画的数量。
dp[i][j]=max(dp[i][j],dp[lson[i]][k]+dp[rson][last_time-k])
#include<cstdio>#include<algorithm>using namespace std;int dp[200][700];int id=0,x,y,s;struct node{ int t,l,r; int v;}tree[200];void init(int now){ scanf("%d%d",&x,&y); tree[now].t=x*2; tree[now].v=y; if(y!=0) tree[id].l=tree[id].r=-1; else { tree[now].l=++id;init(id); tree[now].r=++id;init(id); }}int dfs(int now,int times){ if(dp[now][times]) return dp[now][times]; //记忆化 int last=times-tree[now].t; if(last<0) return 0; if(tree[now].l==-1) return dp[now][times]=min(tree[now].v,last/5); int maxn=0; for(int i=0;i<=last;i++) { maxn=max(maxn,dfs(tree[now].l,i)+dfs(tree[now].r,last-i)); /*这里会调用多次已经计算过的值*/ //计算左儿子i时间,右儿子last-i时间的最大偷画数 } return dp[now][times]=maxn;}int main(){ scanf("%d",&s); init(0); printf("%d\n",dfs(0,s)); return 0;}
4 0
- 【树形DP】wikioi 1163 访问艺术馆
- wikioi 1163 访问艺术馆 树形dp
- 【树形dp】【记忆化】访问艺术馆 WikiOI 1163
- 【树形dp】访问艺术馆
- CodeVS 1163 访问艺术馆(树形DP)
- wikioi-天梯-进入省队-树状dp-1163:访问艺术馆
- 树形DP(访问艺术馆)
- codevs1163 访问艺术馆(树形dp)
- 访问艺术馆 codevs1163 树形dp
- wikioi p1163 访问艺术馆
- 一、树形dp(1)访问艺术馆
- 树形dp 访问艺术馆(又称访问美术馆)
- 1163 访问艺术馆
- 1163 访问艺术馆
- CODEVS 1163 访问艺术馆
- CODEVS 1163 访问艺术馆
- 【Codevs1163】访问艺术馆 树形dp 记忆化搜索(8/1000)
- codevs1163 访问艺术馆(树型dp)
- USB概述协议概述
- IOS自学笔记之Foundation(一)
- [leetcode] Rotate List
- Android Activity的生命周期
- HDU 2833 最大流判满流
- wikioi 1163 访问艺术馆 树形dp
- 【数据库优化(持续更新)】--第一弹设计优化
- IOS自学笔记Foundation (二)
- P2P技术(NAT基础)
- 智能指针总结
- Unity 3D The first project
- 关于绑定变量、关于占位符
- Hadoop 组成
- 如何把C++成员函数的地址传给C