洛谷4294 [WC2008]游览计划——斯坦纳树
题目: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]游览计划——斯坦纳树的更多相关文章
- Luogu 4294 [WC2008]游览计划 | 斯坦纳树
题目链接 Luogu 4294 (我做这道题的时候BZOJ全站的SPJ都炸了 提交秒WA 幸好有洛谷) 题解 这道题是[斯坦纳树]的经典例题.斯坦纳树是这样一类问题:带边权无向图上有几个(一般约10个 ...
- 【BZOJ2595】[Wc2008]游览计划 斯坦纳树
[BZOJ2595][Wc2008]游览计划 Description Input 第一行有两个整数,N和 M,描述方块的数目. 接下来 N行, 每行有 M 个非负整数, 如果该整数为 0, 则该方块为 ...
- 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][ ...
- BZOJ 2595 [Wc2008]游览计划 ——斯坦纳树
[题目分析] 斯坦纳树=子集DP+SPFA? 用来学习斯坦纳树的模板. 大概就是用二进制来表示树包含的点,然后用跟几点表示树的形态. 更新分为两种,一种是合并两个子集,一种是换根,换根用SPFA迭代即 ...
- bzoj2595 [Wc2008]游览计划——斯坦纳树
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2595 今天刚学了斯坦纳树,还不太会,写一道题练习一下: 参考了博客:http://www.c ...
- P4294 [WC2008]游览计划 (斯坦纳树)
题目链接 差不多是斯坦纳树裸题,不过边权化成了点权,这样在合并两棵子树时需要去掉根结点的权值,防止重复. 题目还要求输出解,只要在转移时记录下路径,然后dfs一遍就好了. #include<bi ...
- 洛谷 P7450 - [THUSCH2017] 巧克力(斯坦纳树+随机化)
洛谷题面传送门 9.13 补之前 8.23 做的题,不愧是鸽子 tzc( 首先我们先来探讨一下如果 \(c_{i,j}\le k\) 怎么做,先考虑第一问.显然一个连通块符合条件当且仅当它能够包含所有 ...
- 【BZOJ-2595】游览计划 斯坦纳树
2595: [Wc2008]游览计划 Time Limit: 10 Sec Memory Limit: 256 MBSec Special JudgeSubmit: 1518 Solved: 7 ...
随机推荐
- Vue学习笔记之Vue指令系统介绍
所谓指令系统,大家可以联想咱们的cmd命令行工具,只要我输入一条正确的指令,系统就开始干活了. 在vue中,指令系统,设置一些命令之后,来操作我们的数据属性,并展示到我们的DOM上. OK,接下来我们 ...
- confluence wiki 安装
1. 下载 wget https://www.atlassian.com/software/confluence/downloads/binary/atlassian-confluence-5.6.6 ...
- OpenVAS应用实例
OpenVAS应用实例 首先打开Metasploitables Linux,输入ifconfig查看本机ip地址为192.168.200.125 使用kali linux ping一下Metasplo ...
- FastCGI介绍及Nginx fastcgi配置优化
FastCGI介绍 FastCGI是从CGI发展改进而来的.传统CGI接口方式的主要缺点是性能很差,因为每次HTTP服务器遇到动态程序时都需要重新启动脚本解析器来执行解析,然后结果被返回给HTTP服务 ...
- Linux的硬链接和软链接
1.Linux链接概念Linux链接分两种,一种被称为硬链接(Hard Link),另一种被称为符号链接(Symbolic Link), 也就是软链接.默认情况下,ln命令产生硬链接. [硬连接]硬连 ...
- SQL——DDL简单语句
基于MySQL的: status 命令查看MySQL当前信息 show databases; 命令列出所有数据库模式 use test; use命令切换到指定数据库模式 show tables; 列出 ...
- mac上将代码上传到github以及github对100M以上文件限制上传的处理(lfs)。
前言 有时我们会写一些小程序来学习新的知识,但是完事之后过一段时间可能会忘记,最好的办法就是找到原来的代码看一看.现在可以将代码免费托管到一些网站上,其中最著名的非github莫属了, 今天就把这个过 ...
- IE8 JSON is not defined
问题原因: 昨天遇到了一个问题.就是用ajax从后台查询数据时,返回信息无法显示,经过提示发现是IE控制台提示: JSON is not defined 错误. 而且这个问题在本人自己的电脑上是不存在 ...
- 这些HTML、CSS知识点,面试和平时开发都需要 No10-No11(知识点:表格操作、代码编写规则)
系列知识点汇总 1.基础篇 这些HTML.CSS知识点,面试和平时开发都需要 No1-No4(知识点:HTML.CSS.盒子模型.内容布局) 这些HTML.CSS知识点,面试和平时开发都需要 No5- ...
- Leetcode 64
class Solution { public: int minPathSum(vector<vector<int>>& grid) { int n = grid.si ...