洛谷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 ...
随机推荐
- 2017-2018-1 Java小组-1623 第一周作业
2017-2018-1 Java小组-1623 第一周作业 <构建之法>学习笔记及团队成员介绍 1. 学习内容 概论 个人技术和流程 软件工程师的成长 两人合作 团队和流程 敏捷流程 实战 ...
- InstallShield的工程类型的选择
转载:http://blog.csdn.net/wuxiaoqrs/article/details/45717695 InstallScript vs. Basic MSI InstallScript ...
- Intellij IDEA 创建控制台项目,断点调试快捷方式
在idea 2016中创建一个控制台项目(经常会忘) 打开创建界面 注意,什么都不要选,点击next(最坑的地方,经常忘) 再次点击next ============================= ...
- mysql更改数据文件目录及my.ini位置
步骤: 1.查找my.ini位置,可通过windows服务所对应mysql启动项,查看其对应属性->可执行文件路径,获取my.ini路径. "C:\MySQL\MySQL Server ...
- 【源码学习之spark streaming 1.6.1 】
说明:个人原创,转载请说明出处 http://www.cnblogs.com/piaolingzxh/p/5634577.html 未完待续
- JSP 点击量统计
JSP 点击量统计 有时候我们需要知道某个页面被访问的次数,这时我们就需要在页面上添加页面统计器,页面访问的统计一般在用户第一次载入时累加该页面的访问数上. 要实现一个计数器,您可以利用应用程序隐式对 ...
- 通过电信ADSL无线猫WLAN上网的方法
本教程只适合中国电信ADSL无线猫使用wifi(路由器不适合此帖)我的无线猫是电信赠送的华为[EchoLife]HG522c,亲测可用,解决网关无回应! 首先打开IE(注意,只能是IE,其他内核的浏览 ...
- 2-14-2 MySQL数据类型
MySQL数据类型: 对数据进行分类,针对不同分类进行不同的处理. 1. 使系统能够根据数据类型来操作数据. 2. 预防数据运算时出错. 3. 更有效的利用空间. 数据分类,可以使用最少的存储,来存放 ...
- HDU 4004 二分
The Frog's Games Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65768/65768 K (Java/Others) ...
- UVA-1660 Cable TV Network (最小割)
题目大意:给一张n个点.m条边的无向图,求最小点割集的基数. 题目分析:求无向图最小点割集的基数可以变成求最小割.考虑单源s单汇t的无向图,如果要求一个最小点集,使得去掉这个点集后图不再连通(连通分量 ...