博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
P3360 偷天换日
阅读量:5052 次
发布时间:2019-06-12

本文共 1015 字,大约阅读时间需要 3 分钟。

  还是 树形dp QAQ……

  很开心是第305个通过的(嘿嘿嘿)~

  是上一道题的升级版,但是其实只要把到展厅后简单的除法改成01背包就可以了。

  有一点忘记强调了(莫怪):

  为了保证我们的主人公活着逃出去,所以他至少要在警察来的前一秒钟逃走,所以给他的最长时间是 n - - 。

  代码:

#include
#include
#include
#include
using namespace std;#define maxn 1005#define int long long int f[maxn][maxn],v[maxn],c[maxn],n,num=1;void dfs(int u){ int t,x; scanf("%lld%lld",&t,&x); t*=2; if(x) { for(int i=1; i<=x; i++) scanf("%lld%lld",&c[i],&v[i]); for(int i=1; i<=x; i++) for(int j=n; j>=0; j--) if(j-v[i]>=t) f[u][j]=max(f[u][j],f[u][j-v[i]]+c[i]); return ; } int l=++num; dfs(l); int r=++num; dfs(r); for(int i=t; i<=n; i++) for(int j=0; j<=i-t; j++) f[u][i]=max(f[u][i],f[l][j]+f[r][i-j-t]);}main(){ scanf("%lld",&n); n--; dfs(1); printf("%lld",f[1][n]); return 0;}

 

转载于:https://www.cnblogs.com/popo-black-cat/p/10325026.html

你可能感兴趣的文章
android圆角View实现及不同版本号这间的兼容
查看>>
OA项目设计的能力③
查看>>
Cocos2d-x3.0 文件处理
查看>>
全面整理的C++面试题
查看>>
Activity和Fragment生命周期对比
查看>>
查找 EXC_BAD_ACCESS 问题根源的方法
查看>>
日常报错
查看>>
list-style-type -- 定义列表样式
查看>>
Ubuntu 编译出现 ISO C++ 2011 不支持的解决办法
查看>>
Linux 常用命令——cat, tac, nl, more, less, head, tail, od
查看>>
VueJS ElementUI el-table 的 formatter 和 scope template 不能同时存在
查看>>
Halcon一日一练:图像拼接技术
查看>>
iOS设计模式 - 中介者
查看>>
centos jdk 下载
查看>>
HDU 1028 Ignatius and the Princess III(母函数)
查看>>
(转)面向对象最核心的机制——动态绑定(多态)
查看>>
token简单的使用流程。
查看>>
django创建项目流程
查看>>
Vue 框架-01- 入门篇 图文教程
查看>>
多变量微积分笔记24——空间线积分
查看>>