4007: [JLOI2015]战争调度

Time Limit: 20 Sec Memory Limit: 128 MB
Submit: 396 Solved: 227
[Submit][Status][Discuss]
Description

脸哥最近来到了一个神奇的王国,王国里的公民每个公民有两个下属或者没有下属,这种
关系刚好组成一个 n 层的完全二叉树。公民 i 的下属是 2 * i 和 2 * i +1。最下层的公民即叶子
节点的公民是平民,平民没有下属,最上层的是国王,中间是各级贵族。现在这个王国爆发了
战争,国王需要决定每一个平民是去种地以供应粮食还是参加战争,每一个贵族(包括国王自
己)是去管理后勤还是领兵打仗。一个平民会对他的所有直系上司有贡献度,若一个平民 i 参
加战争,他的某个直系上司 j 领兵打仗,那么这个平民对上司的作战贡献度为 wij。若一个平民
i 种地,他的某个直系上司 j 管理后勤,那么这个平民对上司的后勤贡献度为 fij,若 i 和 j 所
参加的事务不同,则没有贡献度。为了战争需要保障后勤,国王还要求不多于 m 个平民参加
战争。国王想要使整个王国所有贵族得到的贡献度最大,并把这件事交给了脸哥。但不幸的是,
脸哥还有很多 deadline 没有完成,他只能把这件事又转交给你。你能帮他安排吗?
Input

第一行两个数 n;m。接下来 2^(n-1) 行,每行n-1 个数,第 i 行表示编号为 2^(n-1)-1+ i 的平民对其n-1直系上司的作战贡献度,其中第一个数表示对第一级直系上司,即编号为 (2^(n-1)-1+ i)/2 的贵族的作战贡献度 wij,依次往上。接下来 2^(n-1)行,每行n-1个数,第i行表示编号为 2^(n-1)-1+ i的平民对其n-1个直系上司的后勤贡献度,其中第一个数表示对第一级直系上司,即编号为 (2^(n-1)-1+ i)/2 的贵族的后勤贡献度 fij ,依次往上。

Output

一行一个数表示满足条件的最大贡献值

Sample Input

3 4

503 1082

1271 369

303 1135

749 1289

100 54

837 826

947 699

216 389
Sample Output

6701
HINT

对于 100% 的数据,2 <= n <= 10,m <= 2n 1,0 <= wij ;fij <= 2000

其实说是树规,不如说是暴力dfs。f[i][j]点i下辖的平民有j个参加战争时对i的最大贡献。
我们枚举每一个点的状态(后勤,战争)枚举到平民,很容易就计算出f[i][0]和f[i][1]了。之后对于每个贵族(非叶子节点)可以枚举他左右儿子各有多少个下辖平民去战争,加和来更新最大值。
但我为什么说是暴力深搜呢。。。在父亲节点时,要把两个儿子干什么都要枚举一遍(共四种情况)分别计算答案,并且每次搜到这个节点之前要把对应的f数组清空(当前的答案与之前无关)所以真的很暴力。。
因为到叶子结点时所有父亲的状态都确定了,而这个叶子玄哪一者的贡献也就确定了。但是选哪个最优并不能确定,所以这样就可以解决了。

#pragma GCC optimize("O3")
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define N 50005
#define inf 1000000000
using namespace std;
int read()
{int sum=0,f=1;char x=getchar();while(x<'0'||x>'9'){if(x=='-')f=-1;x=getchar();}while(x>='0'&&x<='9'){sum=(sum<<1)+(sum<<3)+x-'0';x=getchar();}return sum*f;
}
int n,m,ans,s,xp[15],f[3000][3000],a[2000][12],b[2000][12],sz[3000];
void dfs(int x,int t)
{if(x>=xp[n-1]){f[x][1]=f[x][0]=0;sz[x]=1;for(int i=1;i<n;i++)if(t&xp[i])f[x][1]+=a[x][i];else f[x][0]+=b[x][i];return;}memset(f[x],0,sizeof(f[x]));dfs(x*2,t<<1);dfs(x*2+1,t<<1);sz[x]=sz[x*2]+sz[x*2+1];for(int i=0;i<=min(m,sz[x]);i++)for(int j=0;j<=i;j++)f[x][i]=max(f[x][i],f[x*2][j]+f[x*2+1][i-j]);dfs(x*2+1,t<<1|1);for(int i=0;i<=min(m,sz[x]);i++)for(int j=0;j<=i;j++)f[x][i]=max(f[x][i],f[x*2][j]+f[x*2+1][i-j]);dfs(x*2,t<<1|1);for(int i=0;i<=min(m,sz[x]);i++)for(int j=0;j<=i;j++)f[x][i]=max(f[x][i],f[x*2][j]+f[x*2+1][i-j]);dfs(x*2+1,t<<1);for(int i=0;i<=min(m,sz[x]);i++)for(int j=0;j<=i;j++)f[x][i]=max(f[x][i],f[x*2][j]+f[x*2+1][i-j]);
}
int main()
{n=read();m=read();xp[0]=1;for(int i=1;i<=n;i++)xp[i]=xp[i-1]*2;for(int i=1;i<=xp[n-1];i++)for(int j=1;j<n;j++)a[xp[n-1]-1+i][j]=read();for(int i=1;i<=xp[n-1];i++)for(int j=1;j<n;j++)b[xp[n-1]-1+i][j]=read();dfs(1,1);for(int i=0;i<=m;i++)ans=max(ans,f[1][i]);dfs(1,0);for(int i=0;i<=m;i++)ans=max(ans,f[1][i]);cout<<ans;
}

转载于:https://www.cnblogs.com/QTY2001/p/7632641.html

树规? bzoj4007 战争调度相关推荐

  1. c++ 不撞南墙不回头——树形动态规划(树规)

    不撞南墙不回头--树规总结                                         焦作一中信息学oy 之所以这样命名树规,是因为树规的这一特殊性:没有环,dfs是不会重复,而 ...

  2. 转不撞南墙不回头——树规总结

    之所以这样命名树规,是因为树规的这一特殊性:没有环,dfs是不会重复,而且具有明显而又严格的层数关系.利用这一特性,我们可以很清晰地根据题目写出一个在树(型结构)上的记忆化搜索的程序.而深搜的特点,就 ...

  3. 不撞南墙不回头——树形动态规划(树规)

    不撞南墙不回头--树规总结                                         焦作一中信息学oy 之所以这样命名树规,是因为树规的这一特殊性:没有环,dfs是不会重复,而 ...

  4. 「JLOI2015」战争调度 解题报告

    「JLOI2015」战争调度 感觉一到晚上大脑就宕机了... 题目本身不难,就算没接触过想想也是可以想到的 这个满二叉树的深度很浅啊,每个点只会和它的\(n-1\)个祖先匹配啊 于是可以暴力枚举祖先链 ...

  5. bzoj4007[JLOI2015]战争调度

    http://www.lydsy.com/JudgeOnline/problem.php?id=4007 搜索. 暴力出奇迹. 题解请戳 发现我一遇到难题手就不由自主地点开了题解~~~~~~~~~~O ...

  6. 【bzoj4007】[JLOI2015]战争调度 暴力+树形背包dp

    题目描述 给你一棵 $n$ 层的完全二叉树,每个节点可以染黑白两种颜色.对于每个叶子节点及其某个祖先节点,如果它们均为黑色则有一个贡献值,如果均为白色则有另一个贡献值.要求黑色的叶子节点数目不超过 $ ...

  7. JLOI2015 战争调度

    题目描述脸哥最近来到了一个神奇的王国,王国里的公民每个公民有两个下属或者没有下属,这种关系刚好组成一个 n 层的完全二叉树.公民 i 的下属是 2 i 和 2 i +1.最下层的公民即叶子节点的公民是 ...

  8. [JLOI2015]战争调度

    文章目录 题目 题解 代码实现 题目 脸哥最近来到了一个神奇的王国,王国里的公民每个公民有两个下属或者没有下属,这种关系刚好组成一个 n 层的完全二叉树. 公民 i 的下属是 2 * i 和 2 * ...

  9. Xenon's Attack on the Gangs(树规)

    题干 Input Output Example Test 1: Test 2: 3 5 1 2 1 2 2 3 1 31 43 53 10 Tips 译成人话 给n个结点,n-1条无向边.即一棵树.我 ...

  10. Evensgn 剪树枝 树规

    f[x][0]表示与其父边相连的连通块内没有黑苹果的方案数, f[x][1]则表示有黑苹果, 如果父边被切断,相当于没有黑苹果 初始化时,假设切掉父边,f[x][0]=1,f[x][1]=0; 递归回 ...

最新文章

  1. 批处理命令学习笔记——Start命令
  2. 通信原理随机信号分析
  3. vue2.0路由之编程式导航
  4. 有意思的onerror的用法
  5. [DBNETLIB][ConnectionOpen(connect()).]SQL Server 不存在或拒绝访问解决方
  6. Python抖音机器人制作!让你有看不完的小姐姐
  7. 深度学习与NLP简单应用
  8. 微信小程序开发【前端+后端(java)】
  9. AudioEffect构造流程跟踪 音效库实现(native侧)
  10. c++调用opencv库实现视频关键帧提取--灰度帧差法
  11. oppo r11s鸿蒙固件,OPPO R11s官方出厂rom系统刷机包下载_卡刷升级包降级回退包
  12. git fetch - git merge - git pull 指令
  13. 规则引擎 Drools:规则引擎概述
  14. Conhost.exe是什么进程?为什么会启动运行?图文详解
  15. linux CentOS7安装VCS、Verdi、SCL
  16. TextBlob简介
  17. Unity3d中异形屏的适配
  18. [MVS]《Non-parametric Depth Distribution Modelling based Depth Inference for Multi-view Stereo》阅读笔记
  19. Python 金融数据分析_8_Python基础(2)
  20. java判断线程结束_java中如何判断一个线程是否结束

热门文章

  1. 最详细windows xp下安装mac的教程(转自远景论坛69nc)
  2. Lattice LSTM
  3. 数据结构常用常考经典习题【按十大专题总结】
  4. 数据结构刘畅c语言版课后答案,数据结构习题集答案--清华大学版
  5. Cell子刊:北大姜长涛组发现HIF-2α通过肠道菌群调控脂肪产热
  6. HDOJ1233 还是畅通工程(kru)
  7. scp 给ipv6_scp传输常用命令
  8. java设计模式4,不要和陌生人说话
  9. 数模国赛备赛(1)元胞自动机CA 生命游戏 森林火灾 传染病模型 MATLAB版资源整理
  10. Kafka【问题 02】KafkaTemplate 报错 Bootstrap broker localhost:9092 (id: -1 rack: null) disconnected 问题解决