题目:https://www.luogu.org/problemnew/show/P4294

大概是状压。两种转移,一个是以同一个点为中心,S由自己的子集拼起来;一个是S相同、中心不同的同层转移。

注意S由自己的子集拼起来的时候要减去一倍的自己位置的代价。

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
using namespace std;
int rdn()
{
int ret=;bool fx=;char ch=getchar();
while(ch>''||ch<''){if(ch=='-')fx=;ch=getchar();}
while(ch>=''&&ch<='')ret=ret*+ch-'',ch=getchar();
return fx?ret:-ret;
}
int Mn(int a,int b){return a<b?a:b;}
const int N=,M=(<<)+,K=,INF=N*(<<);
int n,m,tot,bh[K][K],x[N],y[N],w[N],dp[N][M],bin[K];
queue<int> q; bool ins[N]; int to[N][M][][];
char ch[K][K];
void cz(int k,int d,int s)
{
dp[d][s]=dp[k][s]+w[d];
to[d][s][][]=k;to[d][s][][]=s;to[d][s][][]=to[d][s][][]=;
if(!ins[d])q.push(d),ins[d]=;
}
void spfa(int s)
{
for(int i=;i<=tot;i++)
q.push(i),ins[i]=;
while(q.size())
{
int k=q.front(),d;q.pop();ins[k]=;
if(x[k]>&&dp[d=bh[x[k]-][y[k]]][s]>dp[k][s]+w[d])cz(k,d,s);
if(x[k]<n&&dp[d=bh[x[k]+][y[k]]][s]>dp[k][s]+w[d])cz(k,d,s);
if(y[k]>&&dp[d=bh[x[k]][y[k]-]][s]>dp[k][s]+w[d])cz(k,d,s);
if(y[k]<m&&dp[d=bh[x[k]][y[k]+]][s]>dp[k][s]+w[d])cz(k,d,s);
}
}
void solve(int cr,int s)
{
ch[x[cr]][y[cr]]='o';
if(to[cr][s][][])solve(to[cr][s][][],to[cr][s][][]);
if(to[cr][s][][])solve(to[cr][s][][],to[cr][s][][]);
}
int main()
{
n=rdn();m=rdn();int cnt=;bin[]=;
memset(dp,0x3f,sizeof dp);
for(int i=;i<=n;i++)
for(int j=;j<=m;j++)
{
bh[i][j]=++tot;w[tot]=rdn();
x[tot]=i; y[tot]=j;
if(w[tot])continue; cnt++; bin[cnt]=bin[cnt-]<<;
dp[tot][bin[cnt-]]=;
}
for(int s=;s<bin[cnt];s++)
{
for(int i=;i<=tot;i++)
for(int d=(s-)&s;d;d=(d-)&s)
if(dp[i][d]+dp[i][s^d]-w[i]<dp[i][s])//-w[i]!
{
dp[i][s]=dp[i][d]+dp[i][s^d]-w[i];
to[i][s][][]=to[i][s][][]=i;
to[i][s][][]=d; to[i][s][][]=s^d;
}
spfa(s);
}
int ans=INF,cr[]={,bin[cnt]-};
for(int i=;i<=tot;i++)
if(dp[i][bin[cnt]-]<ans)ans=dp[i][bin[cnt]-],cr[]=i;
solve(cr[],cr[]);
printf("%d\n",ans);
for(int i=;i<=n;i++,puts(""))
for(int j=;j<=m;j++)
if(!w[bh[i][j]])putchar('x');
else if(ch[i][j]=='o')putchar('o');
else putchar('_');
return ;
}

洛谷4294 [WC2008]游览计划——斯坦纳树的更多相关文章

  1. Luogu 4294 [WC2008]游览计划 | 斯坦纳树

    题目链接 Luogu 4294 (我做这道题的时候BZOJ全站的SPJ都炸了 提交秒WA 幸好有洛谷) 题解 这道题是[斯坦纳树]的经典例题.斯坦纳树是这样一类问题:带边权无向图上有几个(一般约10个 ...

  2. 【BZOJ2595】[Wc2008]游览计划 斯坦纳树

    [BZOJ2595][Wc2008]游览计划 Description Input 第一行有两个整数,N和 M,描述方块的数目. 接下来 N行, 每行有 M 个非负整数, 如果该整数为 0, 则该方块为 ...

  3. bzoj2595: [Wc2008]游览计划 斯坦纳树

    斯坦纳树是在一个图中选取某些特定点使其联通(可以选取额外的点),要求花费最小,最小生成树是斯坦纳树的一种特殊情况 我们用dp[i][j]来表示以i为根,和j状态是否和i联通,那么有 转移方程: dp[ ...

  4. BZOJ2595: [Wc2008]游览计划(斯坦纳树,状压DP)

    Time Limit: 10 Sec  Memory Limit: 256 MBSec  Special JudgeSubmit: 2030  Solved: 986[Submit][Status][ ...

  5. BZOJ 2595 [Wc2008]游览计划 ——斯坦纳树

    [题目分析] 斯坦纳树=子集DP+SPFA? 用来学习斯坦纳树的模板. 大概就是用二进制来表示树包含的点,然后用跟几点表示树的形态. 更新分为两种,一种是合并两个子集,一种是换根,换根用SPFA迭代即 ...

  6. bzoj2595 [Wc2008]游览计划——斯坦纳树

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2595 今天刚学了斯坦纳树,还不太会,写一道题练习一下: 参考了博客:http://www.c ...

  7. P4294 [WC2008]游览计划 (斯坦纳树)

    题目链接 差不多是斯坦纳树裸题,不过边权化成了点权,这样在合并两棵子树时需要去掉根结点的权值,防止重复. 题目还要求输出解,只要在转移时记录下路径,然后dfs一遍就好了. #include<bi ...

  8. 洛谷 P7450 - [THUSCH2017] 巧克力(斯坦纳树+随机化)

    洛谷题面传送门 9.13 补之前 8.23 做的题,不愧是鸽子 tzc( 首先我们先来探讨一下如果 \(c_{i,j}\le k\) 怎么做,先考虑第一问.显然一个连通块符合条件当且仅当它能够包含所有 ...

  9. 【BZOJ-2595】游览计划 斯坦纳树

    2595: [Wc2008]游览计划 Time Limit: 10 Sec  Memory Limit: 256 MBSec  Special JudgeSubmit: 1518  Solved: 7 ...

随机推荐

  1. 项目中使用protobuf 3.0

    protocol buffer从3.0 原生的compiler支持c++,Java,Python,Go,Ruby,JavaNano,JavaScript,Objective-C,C#,PHP这篇文章作 ...

  2. 20145118 《Java程序设计》 实验报告一

    实验一 JAVA开发环境的熟悉(LINUX + ECLIPSE) 实验内容 1.使用JDK编译.运行简单的Java程序: 2.使用Eclipse 编辑.编译.运行.调试Java程序. 3.统计自己的P ...

  3. ZooKeeper增加Observer部署模式提高性能(转)

    除了Leader和Follow模式之外,还有第三种模式:Observer模式. Observer:在不伤害写性能的情况下扩展ZooKeeper. 虽然通过Client直接连接到ZooKeeper集群的 ...

  4. Bitmap 位图

    转自: http://dongxicheng.org/structure/bitmap/ 1.  概述 位图(bitmap)是一种非常常用的结构,在索引,数据压缩等方面有广泛应用.本文介绍了位图的实现 ...

  5. [Pytorch]Pytorch 细节记录(转)

    文章来源 https://www.cnblogs.com/king-lps/p/8570021.html 1. PyTorch进行训练和测试时指定实例化的model模式为:train/eval eg: ...

  6. 【p4tutorials】P4 v1.1 Simple Router

    fork了p4tutorials,想从里面窥探一些门道. 本文相关的原文链接:ReadMe 说明: 下面的这个P4程序,是当下最著名的 simple_router 程序的一个版本,是根据P4的1.1版 ...

  7. UI 交互

    动效设计 亮色优缺点 排版 原型图交互说明

  8. mysql数据库的备份及免密码上传

    主要利用了mysqldump和sshpass进行备份和免密上传 以下是代码实现: #!/bin/bash #该脚本放在主服务器运行 #从服务器账号密码ipremotehost="xxxxxx ...

  9. 046——VUE中组件之使用动态组件灵活设置页面布局

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  10. elasticsearch搜索引擎学习1

    用elasticsearch-river-jdbc同步数据到elasticsearch 用elasticsearch-river-jdbc同步数据到elasticsearch 1 插件安装  插件的g ...