【BZOJ】2595: [Wc2008]游览计划
题意
\(n * m\)的网格,如果\(a_{i, j} = 0\)则表示景点,否则表示这里的需要的志愿者人数。求一种安排志愿者的方案使得所有景点连通且志愿者最少。
分析
本题可以插头dp,然而有一个东西叫斯坦纳树,来学习学习。
令\(f(i, j, s)\)表示\((i, j)\)为根,连通性为\(s\)的最少志愿者。则有转移:
$$
f(i, j, s) = min
\begin{cases}
f(i, j, t) + f(i, j, s-t) - a_{i, j} & t \neq \varnothing, t \subset s \\
f(i', j', s) & (i, j)与(i', j')相邻 \\
\end{cases}
$$
第一个转移可以直接做,然而第二个转移不是\(dag\)= =,所以我们得用最短路来求出来。
所以我们状压dp一下,然后每一个状态\(s\)先更新了第一种转移,然后再最短路一下。
然后完了= =
题解
如分析。
#include <bits/stdc++.h>
using namespace std;
const int N=10, M=N*N+5, oo=0x3f3f3f3f, dx[]={1, -1, 0, 0}, dy[]={0, 0, 1, -1};
int n, m, a[N][N], f[N][N][1<<N], p[N][N][1<<N], go[N][N], q[M], ta, fr, tot;
bool vis[N][N], ok[N][N];
void init() {
memset(f, 0x3f, sizeof f);
memset(p, -1, sizeof p);
scanf("%d%d", &n, &m);
for(int i=0; i<n; ++i) {
for(int j=0; j<m; ++j) {
scanf("%d", &a[i][j]);
if(!a[i][j]) {
f[i][j][go[i][j]=1<<tot++]=0;
}
}
}
}
inline int hash(const int x, const int y, const int s) {
return y+x*100+s*10000;
}
void spfa(int s) {
while(fr!=ta) {
int h=q[fr++], y=h%100, x=h/100;
fr=fr==M?0:fr;
for(int k=0; k<4; ++k) {
int fx=x+dx[k], fy=y+dy[k];
if(fx<0 || fx>=n || fy<0 || fy>=m) {
continue;
}
int temp=f[x][y][s]+a[fx][fy];
if(f[fx][fy][s]>temp) {
f[fx][fy][s]=temp;
if(!vis[fx][fy]) {
vis[fx][fy]=1;
q[ta++]=hash(fx, fy, 0);
ta=ta==M?0:ta;
}
p[fx][fy][s]=hash(x, y, s);
}
}
vis[x][y]=0;
}
fr=ta=0;
}
void work() {
int all=1<<tot;
for(int s=1; s<all; ++s) {
for(int i=0; i<n; ++i) {
for(int j=0; j<m; ++j) {
for(int t=s&(s-1); t; t=s&(t-1)) {
int temp=f[i][j][t]+f[i][j][s-t]-a[i][j];
if(f[i][j][s]>temp) {
f[i][j][s]=temp;
p[i][j][s]=hash(i, j, t);
}
}
if(f[i][j][s]!=oo) {
vis[i][j]=1;
q[ta++]=hash(i, j, 0);
}
}
}
spfa(s);
}
}
void dfs(int i, int j, int s) {
ok[i][j]=1;
int h=p[i][j][s];
if(h<0) {
return;
}
int y=h%100, x=(h%10000)/100, t=h/10000;
dfs(x, y, t);
if(i==x && j==y) {
dfs(x, y, s-t);
}
}
void out() {
for(int i=0; i<n; ++i) {
for(int j=0; j<m; ++j) {
if(go[i][j]) {
printf("%d\n", f[i][j][(1<<tot)-1]);
dfs(i, j, (1<<tot)-1);
return;
}
}
}
}
void prin() {
out();
for(int i=0; i<n; ++i) {
for(int j=0; j<m; ++j) {
if(go[i][j]) {
putchar('x');
}
else if(ok[i][j]) {
putchar('o');
}
else {
putchar('_');
}
}
puts("");
}
}
int main() {
init();
work();
prin();
return 0;
}
【BZOJ】2595: [Wc2008]游览计划的更多相关文章
- bzoj 2595 [Wc2008]游览计划(斯坦纳树)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2595 [题意] 给定N*M的长方形,选最少权值和的格子使得要求的K个点连通. [科普] ...
- bzoj:2595: [Wc2008]游览计划
Description Input 第一行有两个整数,N和 M,描述方块的数目. 接下来 N行, 每行有 M 个非负整数, 如果该整数为 0, 则该方块为一个景点:否则表示控制该方块至少需要的志愿者数 ...
- BZOJ 2595: [Wc2008]游览计划 [DP 状压 斯坦纳树 spfa]【学习笔记】
传送门 题意:略 论文 <SPFA算法的优化及应用> http://www.cnblogs.com/lazycal/p/bzoj-2595.html 本题的核心就是求斯坦纳树: Stein ...
- BZOJ.2595.[WC2008]游览计划(DP 斯坦纳树)
题目链接 f[i][s]表示以i为根节点,当前关键点的连通状态为s(每个点是否已与i连通)时的最优解.i是枚举得到的根节点,有了根节点就容易DP了. 那么i为根节点时,其状态s的更新为 \(f[i][ ...
- BZOJ 2595 [Wc2008]游览计划 ——斯坦纳树
[题目分析] 斯坦纳树=子集DP+SPFA? 用来学习斯坦纳树的模板. 大概就是用二进制来表示树包含的点,然后用跟几点表示树的形态. 更新分为两种,一种是合并两个子集,一种是换根,换根用SPFA迭代即 ...
- 【BZOJ 2595】2595: [Wc2008]游览计划 (状压DP+spfa,斯坦纳树?)
2595: [Wc2008]游览计划 Time Limit: 10 Sec Memory Limit: 256 MBSec Special JudgeSubmit: 1572 Solved: 7 ...
- 【LG4294】[WC2008]游览计划
[LG4294][WC2008]游览计划 题面 洛谷 bzoj 题解 斯坦纳树板子题. 斯坦纳树的总结先留个坑. 代码 #include <iostream> #include <c ...
- BZOJ_2595_[Wc2008]游览计划_斯坦纳树
BZOJ_2595_[Wc2008]游览计划_斯坦纳树 题意: 分析: 斯坦纳树裸题,有几个需要注意的地方 给出矩阵,不用自己建图,但枚举子集转移时会算两遍,需要减去当前点的权值 方案记录比较麻烦,两 ...
- [WC2008]游览计划 解题报告
[WC2008]游览计划 斯坦纳树板子题,其实就是状压dp 令\(dp_{i,s}\)表示任意点\(i\)联通关键点集合\(s\)的最小代价 然后有转移 \[ dp_{i,S}=\min_{T\in ...
随机推荐
- **PHP中替换换行符
PHP中替换换行符 php 不同系统的换行不同系统之间换行的实现是不一样的linux 与unix中用 \nMAC 用 \rwindow 为了体现与linux不同 则是 \r\n所以在不同平台上 实现方 ...
- Android浏览本地 API文档 + 解决页面加载慢的问题
火狐浏览器安装离线浏览插件: 用浏览器打开index.html文件,你会发现加载的很慢,原因你懂的,为此,我们可以通过离线的方式 查看本地API文档,用火狐浏览器 + Work Offline插 ...
- SQL中的JOIN类型解释(CROSS, INNER,OUTER),关键字ON,USING
书上讲得明白,解了不少迷惑. SELECT e.fname, e.lname, d.name FROM employee AS e INNER JOIN department AS d ON e.de ...
- 分享一个最近研究的手机QQ3.0的协议(版本1.4)
最近闲来有事, 分析了一个非常低端(非常低端的意思是说你不应该对她是否能取代你现有的QQ客户端作任何可能的奢望,她只是一个实验性的东西)的手机QQ的协议, 是手机QQ3.0, 所用到的TCP ...
- GitHub 中国区前 100 名到底是什么样的人?
本文根据Github公开API,抓取了地址显示China的用户,根据粉丝关注做了一个排名,分析前一百名的用户属性,剖析这些活跃在技术社区的牛人到底是何许人也!后续会根据我的一些经验出品<技术人员 ...
- 《Spring 3.x 企业应用开发实战》目录
图书信息:陈雄华 林开雄 编著 ISBN 978-7-121-15213-9 概述: 第1章:对Spring框架进行宏观性的概述,力图使读者建立起对Spring整体性的认识. 第2章:通过一个简单的例 ...
- [SQL]oracle 的to_char、to_number、to_date用法
关键字: oracle 的to_char.to_number.to_date用法 TO_CHAR 是把日期或数字转换为字符串TO_DATE 是把字符串转换为数据库中得日期类型转换函数TO_NUMBER ...
- DTMF的原理分析
转自:http://blog.csdn.net/wangwenwen/article/details/8264925 1. DTMF原理 DTMF(Double Tone MulitiFrequenc ...
- Ubuntu 上安装 MongoDB
官方安装文档:https://docs.mongodb.com/manual/installation/ 安装环境: mongodb-linux-x86_64-ubuntu1404-3.2.6.tgz ...
- NSDate用法整理总结
int main(int argc, const char * argv[]) { @autoreleasepool { NSDate *date=[NSDate date]; NSLog(@&quo ...