【BZOJ2595】 [Wc2008]游览计划
BZOJ2595 [Wc2008]游览计划
Solution
考虑这是一个最小费用连通性的问题,既然大家都说这是什么斯坦纳树那就是的吧...
所以我们肯定可以这样设一个dp状态:
\(dp_{i,j,k}\)表示经过点(i,j)且现在连通性为\(k\)的最小费用.
有两种转移方程:
\(dp_{i,j,k}=dp_{i,j,s}+dp_{i,j,k-s}-a[i][j];\)
\(dp_{i,j,k}=dp_{x,y,k}+a[i][j]\)
这个还是比较显然?
发现后面那个东西很像最短路不是吗?
直接SPFA+dp转移一下就好了.
代码实现
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
#include<algorithm>
#include<queue>
#include<set>
#include<map>
#include<iostream>
using namespace std;
#define ll long long
#define re register
#define file(a) freopen(a".in","r",stdin);freopen(a".out","w",stdout)
inline int gi()
{
int f=1,sum=0;char ch=getchar();
while(ch>'9' || ch<'0'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0' && ch<='9'){sum=(sum<<3)+(sum<<1)+ch-'0';ch=getchar();}
return f*sum;
}
const int N=20,Inf=1e9;
int bin[N],f[12][12][1024],vis[N][N];
int wa[4]={1,0,-1,0};
int lk[4]={0,1,0,-1};
struct node{
int a,b,c;
}pre[12][12][60010];
int a[N][N],n,m,b[N][N];
typedef pair<int,int> pii;
#define mp make_pair
queue<pii>Q;
void spfa(int s){
while(!Q.empty()){
pii now=Q.front();Q.pop();
int x=now.first,y=now.second;vis[x][y]=0;
for(int i=0;i<4;i++){
int xx=x+wa[i],yy=y+lk[i];
if(xx<1 || xx>n || yy<1 || yy>m)continue;
if(f[xx][yy][s]>f[x][y][s]+a[xx][yy]){
f[xx][yy][s]=f[x][y][s]+a[xx][yy];
pre[xx][yy][s]=(node){x,y,s};
if(!vis[xx][yy]){
vis[xx][yy]=1;Q.push(mp(xx,yy));
}
}
}
}
}
void dfs(int i,int j,int s)
{
if(i>=Inf || pre[i][j][s].c==0)return;
b[i][j]=1;node q=pre[i][j][s];
dfs(q.a,q.b,q.c);
if(q.a==i && q.b==j)dfs(i,j,s-q.c);
}
int main()
{
int K=0;
bin[0]=1;for(int i=1;i<20;i++)bin[i]=bin[i-1]<<1;
n=gi();m=gi();
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++){
a[i][j]=gi();
if(!a[i][j])K++;
}
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
for(int k=0;k<bin[K];k++)
f[i][j][k]=pre[i][j][k].a=Inf;
K=0;
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)
if(!a[i][j])
f[i][j][bin[K]]=0,K++;
for(int s=1;s<bin[K];s++){
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++){
for(int ss=s&(s-1);ss;ss=s&(ss-1)){
int t=f[i][j][ss]+f[i][j][s-ss]-a[i][j];
if(t<f[i][j][s]){
f[i][j][s]=t;pre[i][j][s]=(node){i,j,ss};
}
}
if(f[i][j][s]<Inf){
Q.push(mp(i,j));vis[i][j]=1;
}
}
spfa(s);
}
int x=0,y;
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++)
if(!a[i][j]){
x=i;y=j;break;
}
if(x)break;
}
dfs(x,y,bin[K]-1);
printf("%d\n",f[x][y][bin[K]-1]);
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++)
if(!a[i][j])putchar('x');
else if(b[i][j])putchar('o');
else putchar('_');
putchar('\n');
}
return 0;
}
【BZOJ2595】 [Wc2008]游览计划的更多相关文章
- BZOJ2595 Wc2008 游览计划 【斯坦纳树】【状压DP】*
BZOJ2595 Wc2008 游览计划 Description Input 第一行有两个整数,N和 M,描述方块的数目. 接下来 N行, 每行有 M 个非负整数, 如果该整数为 0, 则该方块为一个 ...
- [bzoj2595][WC2008]游览计划/[bzoj5180][Baltic2016]Cities_斯坦纳树
游览计划 bzoj-2595 wc-2008 题目大意:题目链接.题目连接. 注释:略. 想法:裸题求斯坦纳树. 斯坦纳树有两种转移方式,设$f[s][i]$表示联通状态为$s$,以$i$为根的最小代 ...
- BZOJ2595 WC2008游览计划(斯坦纳树)
斯坦纳树板子题. 考虑状压dp,设f[i][j][S]表示当前在点(i,j)考虑转移,其所在的联通块包含的关键点集(至少)为S的答案. 转移时首先枚举子集,有f[i][j][S]=min{f[i][j ...
- BZOJ2595 [Wc2008]游览计划 【状压dp + 最短路】
题目链接 BZOJ2595 题解 著名的斯坦纳树问题 设\(f[i][j][s]\)表示点\((i,j)\)与景点联通状况为\(s\)的最小志愿者数 设\(val[i][j]\)为\((i,j)\)需 ...
- bzoj2595 [Wc2008]游览计划——斯坦纳树
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2595 今天刚学了斯坦纳树,还不太会,写一道题练习一下: 参考了博客:http://www.c ...
- BZOJ2595[WC2008]游览计划
Description Input 第一行有两个整数,N和 M,描述方块的数目. 接下来 N行, 每行有 M 个非负整数, 如果该整数为 0, 则该方块为一个景点:否则表示控制该方块至少需要的志愿者数 ...
- 斯坦纳树 [bzoj2595][wc2008]游览计划 题解
话说挺早就写过斯坦纳树了,不过当时没怎么总结,也不是很理解……现在来个小结吧~ 斯坦纳树就是包含给定点的最小生成树(个人理解权值应当为正). 一般来讲,给定点的数目应该很小吧...于是我们可以用状压D ...
- bzoj2595: [Wc2008]游览计划 斯坦纳树
斯坦纳树是在一个图中选取某些特定点使其联通(可以选取额外的点),要求花费最小,最小生成树是斯坦纳树的一种特殊情况 我们用dp[i][j]来表示以i为根,和j状态是否和i联通,那么有 转移方程: dp[ ...
- BZOJ2595: [Wc2008]游览计划(斯坦纳树,状压DP)
Time Limit: 10 Sec Memory Limit: 256 MBSec Special JudgeSubmit: 2030 Solved: 986[Submit][Status][ ...
随机推荐
- tomcat运行监控脚本,自动启动
参见:http://www.cnblogs.com/coffee_cn/p/8279165.html monitor.sh #!/bin/sh monitorlog=/usr/local/tomcat ...
- kbmmw ORM 对象定义语法简析
使用kbmmw 的ORM 一定先要了解ORM 的对象定义语法. 下面简单说一下 // kbmMW_Table - Define a table. 定义一个表 // Must be used on cl ...
- kbmmw 中JSON 操作入门
现在各种系统中JSON 用的越来越多.delphi 也自身支持JSON 处理. 今天简要说一下kbmmw 内部如何使用和操作JSON. kbmmw 中json的操作是以TkbmMWJSONStream ...
- 整合SPRING CLOUD云服务架构 - 企业分布式微服务云架构构建
整合SPRING CLOUD云服务架构 - 企业分布式微服务云架构构建 1. 介绍 Commonservice-system是一个大型分布式.微服务.面向企业的JavaEE体系快速研发平台,基于模 ...
- hashable/iterable与orderable
################ # hashable协议 # ################ # 一个对象能被称为hashable,它必须实现__hash__与_eq__方法: >>& ...
- CSS Sprites (CSS 精灵) 技术
CSS Sprites在国内很多人叫css精灵,是一种网页图片应用处理方式.它允许你将一个页面涉及到的所有零星图片都包含到一张大图中去,这样一来,当访问该页面时,载入的图片就不会像以前那样一幅一幅地慢 ...
- 检索 COM 类工厂中 CLSID 为 {10021F00-E260-11CF-AE68-00AA004A34D5} 的组件失败,原因是出现以下错误: 80040154 没有注册类 (异常来自 HRESULT:0x80040154 (REGDB_E_CLASSNOTREG))。
ASP.NET利用SQLDMO可以实现在线备份.还原数据库等各种功能. 由于客户的数据库和WEB服务不再同一台服务器,把网站部署在服务器上以后,运行程序,提示如下错误 当使用Interop.SQLDM ...
- IntelliJ IDEA 2017版 Spring5 java.lang.NoSuchMethodError: org.springframework.boot.SpringApplication.<init>([Ljava/lang/Object;)V
错误是java.lang.NoSuchMethodError: org.springframework.boot.SpringApplication.<init>([Ljava/lang/ ...
- IDEA插件开发总结
一:前置步骤 1.添加开发插件所需的SDK: 1.1先添加JDK 1.2打开Project Structure-Platform Settings-SDKs 1.3添加IntelliJ Platfor ...
- hibernate4.3.5,Final hibernate.cfg.xml的配置
今天是接触hibernate的第二天,用来练习的是hibernate最新的版本hibernate-release-4.3.5.Final 要使用hibernate,则先要引入它的jar包,要引入的ja ...