jzoj3737-[NOI2014模拟7.11]挖宝藏(treasure)【斯坦纳树,SPFA,状压】

正题


题目大意

hhh层,每层n∗mn*mnm个石头,挖开不同位置的石头有不同的消耗,只能从高层下到低层。有一些宝藏,求拿到所有宝藏的最小代价。


解题思路

先考虑只有111层的情况,因为挖开的不用再挖 ,我们可以发现本题就是一个斯坦纳树,我们用SSS状压宝藏的拿取情况。

然后有动态转移方程
fS,x,y={fS′,x,y+fS−S′,x,y−ax,y(S′∈S)fS,x−1,y+ax,yfS,x+1,y+ax,yfS,x,y−1+ax,yfS,x,y+1+ax,yf_{S,x,y}=\left\{\begin{matrix} f_{S',x,y}+f_{S-S',x,y}-a_{x,y}(S'\in S) \\ f_{S,x-1,y}+a_{x,y} \\ f_{S,x+1,y}+a_{x,y} \\ f_{S,x,y-1}+a_{x,y} \\ f_{S,x,y+1}+a_{x,y} \end{matrix}\right.fS,x,y=fS,x,y+fSS,x,yax,y(SS)fS,x1,y+ax,yfS,x+1,y+ax,yfS,x,y1+ax,yfS,x,y+1+ax,y
本方程有后效性且与最短路形式较为相似所以我们枚举SSS先计算第一个后跑一遍SPFASPFASPFA即可

然后我们考虑多层时从下往上递推,先将fff多开一维表示层。然后我们可以将上层多开一个宝藏点表示是否选择了下层的所有宝藏
然后有递推式fz,1,x,y=fz+1,2kz+1+1−1,x,yf_{z,1,x,y}=f_{z+1,2^{k_{z+1}+1}-1,x,y}fz,1,x,y=fz+1,2kz+1+11,x,y


codecodecode

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#define ll long long
using namespace std;
const ll dx[4]={1,-1,0,0},dy[4]={0,0,1,-1},N=15,M=1<<10;
ll h,n,m,g[N][N][N],f[N][M][N][N],ans,a[N][N][N],k[N];
bool v[N][N];
queue<int> qx,qy;
void Spfa(ll z,ll s)
{for(ll x=1;x<=n;x++)for(ll y=1;y<=m;y++)qx.push(x),qy.push(y),v[x][y]=1;while(!qx.empty()){ll x=qx.front(),y=qy.front();qx.pop();qy.pop();for(ll i=0;i<4;i++){ll zx=x+dx[i],zy=y+dy[i];if(zx<1||zy<1||zx>n||zy>m) continue;if(f[z][s][x][y]+a[z][zx][zy]>=f[z][s][zx][zy]) continue;f[z][s][zx][zy]=f[z][s][x][y]+a[z][zx][zy];if(!v[zx][zy]){v[zx][zy]=1;qx.push(zx);qy.push(zy);} }v[x][y]=0;}
}
int main()
{freopen("treasure.in","r",stdin);freopen("treasure.out","w",stdout);scanf("%lld%lld%lld",&h,&n,&m);for(ll i=1;i<=h;i++)for(ll j=1;j<=n;j++)for(ll k=1;k<=m;k++)scanf("%lld",&a[i][j][k]);memset(f,127,sizeof(f));memset(f[h+1],0,sizeof(f[h+1]));for(ll z=1;z<=h;z++){scanf("%lld",&k[z]); for(ll i=0;i<k[z];i++){ll x,y;scanf("%lld%lld",&x,&y);g[z][x][y]|=1<<i;}}for(ll z=h;z>=1;z--){ll LMS=(1<<k[z+1])-1,MS=(1<<k[z]);for(ll i=1;i<=n;i++)for(ll j=1;j<=m;j++)f[z][MS+g[z][i][j]][i][j]=f[z+1][LMS][i][j]+a[z][i][j],f[z][g[z][i][j]][i][j]=a[z][i][j];MS=(1<<(++k[z]))-1;for(ll s=0;s<=MS;s++){for(ll i=1;i<=n;i++)for(ll j=1;j<=m;j++){int l=s;while(l){l=((l-1)&s);if(!l) break;if(max(f[z][l][i][j],f[z][s-l][i][j])<1e17)f[z][s][i][j]=min(f[z][s][i][j],f[z][l][i][j]+f[z][s-l][i][j]-a[z][i][j]);}}Spfa(z,s);}}ans=1e17;ll MS=(1<<k[1])-1;for(ll i=1;i<=n;i++)for(ll j=1;j<=m;j++)ans=min(ans,f[1][MS][i][j]);printf("%lld",ans);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/322084.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringCloud Zuul(八)之ERROR Filter

一、ERROR Filter 错误过滤器用来处理zuul异常&#xff0c;一般使作为打印异常堆栈、跳转异常页面、转换异常信息格式返回等操作。 Zuul已定义的错误过滤器SendErrorFilter&#xff0c;如果RequestContext.getThrowable()不为null&#xff0c;则转发到/error&#xff08;默认…

Alex: 2018年对混合现实MR的展望

原文作者&#xff1a;Alex Kipman&#xff0c; 微软操作系统工程院技术院士 Hello 大家好&#xff01;难以置信我们已经走过了2018年的头两个月了。每年一月份我都会去巴西省亲&#xff0c;和我的家人欢聚一堂&#xff0c;度过一个美好的假日。在我省亲的同时&#xff0c;我想了…

jzoj3738-[NOI2014模拟7.11]理想城市(city)【树,模型转换】

正题 题目大意 一个理想城市有nnn个块构成&#xff0c;有以下性质 任意两个块之间可以通过其他块到达任意两个块之间可以不通过其他块(通过空位)到达 然后求每个块之间的距离之和。 解题思路 我们将横竖的距离分开计算。 假设现在我们考虑计算竖向的边的距离&#xff0c;我…

SpringCloud Ribbon(二)之自定义负载均衡策略IRule

一、Ribbon负载均衡策略 一个服务对应一个LoadBalancer&#xff0c;一个LoadBalancer只有一个Rule&#xff0c;LoadBalancer记录服务的注册地址&#xff0c;Rule提供从服务的注册地址中找出一个地址的规则。 Ribbon提供七种负载均衡策略&#xff0c;默认的负载均衡策略是轮训策…

欢乐纪中A组赛【2019.8.10】

前言 昨天&#xff1a; MdMdMd今天还真爆零了 顺便%%%ZZYRank1\%\%\%ZZY\ Rank1%%%ZZY Rank1 成绩 JJJ表示初中&#xff0c;HHH表示高中后面加的是几年级 RankRankRankPersonPersonPersonScoreScoreScoreAAABBBCCC111(H−1)ZZY(H-1)ZZY(H−1)ZZY1501501502020203030301001001…

Blazor正式成为Microsoft官方.NET 和WebAssembly项目

Microsoft从Blazor的开发者Steve Sanderson手中接手了这款应用程序&#xff0c;自此&#xff0c;将.NET在浏览器运行的计划又更进了一步。由此&#xff0c;Microsoft又进一步扩充了自己的WebAssembly/.NET栈&#xff0c;更进一步帮助.NET开发人员搭建基于浏览器的应用程序。在一…

SpringCloud Ribbon(一)之自定义负载均衡器ILoadBalancer

一、Ribbon负载均衡 一个服务对应一个LoadBalancer&#xff0c;一个LoadBalancer只有一个Rule&#xff0c;LoadBalancer记录服务的注册地址&#xff0c;提供更新服务的注册地址&#xff0c;Rule提供从服务的注册地址中找出一个地址的规则。 二、 自定义负载均衡 本文自定义负…

bzoj4403-序列统计【Lucas,组合数学】

正题 题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id4403 题目大意 求有多少个长度为nnn的单调不升序列&#xff0c;且对于每个元素都∈[L,R]\in[L,R]∈[L,R] 解题思路 我们让mR−L1mR-L1mR−L1&#xff0c;因为序列的要求起始起始不会影响结果 然后我们开始考…

.NET Core 2.1路线图

Microsoft的Scott Hunter发布了Microsoft .NET Core 2.1版本的路线图。Hunter宣布Microsoft .NET Core每天约有五十万开发人员的使用量。根据Microsoft所收集的数据&#xff0c;在2017年9月.NET Core 2的使用量已经超过了.NET Core 1.X。有了之前成功的发布经验&#xff0c;Mic…

SpringCloud Ribbon(三)之IPing机制

一、IPing机制 IPing是一个主动探测服务节点存活的机制&#xff0c;通过判断服务节点的当前状态&#xff0c;设置节点的可用状态。只有当节点为可用时候才会作为负载均衡器的选取节点。 IPing有以下几种模式: DummyPing&#xff1a;默认返回true&#xff0c;即认为所有节点都…

.NET Core使用swagger进行API接口文档管理

一、问题背景随着技术的发展&#xff0c;现在的开发模式已经更多的转向了前后端分离的模式&#xff0c;在前后端开发的过程中&#xff0c;联系的方式也变成了API接口&#xff0c;但是目前项目中对于API的管理很多时候还是通过手工编写文档&#xff0c;每次的需求变更只要涉及到…

CF451E-Devu and Flowers【组合计数,容斥】

正题 题目链接:https://www.luogu.org/problem/CF451E 题目大意 长度为nnn的序列aia_iai​&#xff0c;有如下要求 ai∈[0...xi]a_i\in[0...x_i]ai​∈[0...xi​]∑i1nais\sum_{i1}^na_is∑i1n​ai​s 求序列个数。 解题思路 考虑容斥&#xff0c;这样我们就可以将条件转换…

SpringCloud Ribbon(四)之全局配置与服务配置

一、Ribbon全局配置 RibbonClients注解配置导入全局Ribbon客户端默认设置 public class GlobalRibbonConfig {//负载均衡策略Beanpublic IRule rule() {return new MicroServiceLoadBalanceRule();}//负载均衡器Beanpublic <E extends Server> ILoadBalancer loadBalan…

.NET下使用socket.io随笔记录

一、问题背景目前公司在互联网产品上需要程序与前端部分要进行一个实时交互&#xff0c;在进行一定程度上的选型后&#xff0c;决定使用socket.io框架进行一个实践&#xff0c;算是公司的一个新的 尝试&#xff0c;也算是给自己增加增长见闻&#xff0c;由于我是做后端以及桌面…

bzoj2111,P2606-[ZJOI2010]排列计数【Lucas,组合计数,dp】

正题 题目链接: https://www.lydsy.com/JudgeOnline/problem.php?id2111 https://www.luogu.org/problem/P2606 题目大意 长为nnn的序列PPP&#xff0c;然后要求Pi>P⌊i2⌋P_i>P_{\lfloor \frac{i}{2}\rfloor}Pi​>P⌊2i​⌋​。求排列个数。 解题思路 若用iii连向…

SpringCloud Ribbon(五)之服务实例列表ServerList

一、服务实例列表ServerList 服务实例列表&#xff08;ServerList&#xff09;为负载均衡器&#xff08;Loadbalancer&#xff09;提供服务的可用实例列表。 负载均衡器&#xff08;Loadbalancer&#xff09;通过服务实例列表&#xff08;ServerList&#xff09;从注册中心&a…

超级简便的容器化部署工具(使用 ASP.NET Core 演示)

Docker 改变了我们部署网站的方式&#xff0c;从原先的手动编译打包上传&#xff0c;到现在的构建镜像然后推送部署&#xff0c;让我们在配置环境上所花费的时间大大减少了。不仅如此&#xff0c;通过一系列相关的工具配合&#xff0c;可以很轻松的实现 CI、CD。本文即将介绍的…

学习手记(2019/7/05~2019/8/31)——快乐暑假

文章目录二分答案的作用堆和区间很糙ddp线段树合并网络流结论の1树上莫队对角线与GCD区间与扫描线与方案数欧拉欧拉*1斯坦纳树切比雪夫距离二分匹配结论の1min-max容斥计算几何の -1二分答案的作用 求最大值最小ororor最小值最大将求值问题转换为判断问题在判断问题之间相互转…

SpringCloud Ribbon(六)之服务实例过滤器ServerListFilter

一、服务实例过滤器ServerListFilter 服务实例过滤器&#xff08;ServerListFilter&#xff09;为负载均衡器&#xff08;Loadbalancer&#xff09;提供从服务实例列表&#xff08;ServerList&#xff09;获取的服务实例过滤出符合要求的服务实例。 负载均衡器&#xff08;Lo…

听说你开发.NET还在用VS,小哥哥给你推荐全平台的Rider

前言.NET平台的开发一直都只能使用Visual Studio来开发&#xff0c;自从dotnet core 发布后不久&#xff0c;jetbrains 发布了Rider预览版&#xff0c;到目前为止的正式版2017.3.1。博主都使用过&#xff0c;因为博主的主力开发语言是C#&#xff0c;所以一直以来被捆绑到Window…