【BZOJ】【2595】【WC2008】游览计划
Orz zky神犇http://blog.csdn.net/iamzky/article/details/42029921
spfa的灵活应用!(好像是求了一个叫做斯坦纳树的东西……)
o(︶︿︶)o 唉我就是太水了,离散化写跪了,x*1e5+y*1e4+k,但是这题里我x和y的范围是[1,10]所以在y==10的时候会出错!!
//BZOJ 2595
#include<queue>
#include<cmath>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#define rep(i,n) for(int i=0;i<n;++i)
#define F(i,j,n) for(int i=j;i<=n;++i)
#define D(i,j,n) for(int i=j;i>=n;--i)
using namespace std;
const int N=,INF=~0u>>;
const int fx[]={,,-,},
fy[]={,,,-};
typedef long long LL;
//#define debug
int n,m,a[N][N],d[N][N],cnt=;
int f[N][N][],pre[N][N][];
bool vis[N][N]; struct node{ int x,y; };
queue<node>Q;
inline int pack(int x,int y,int s){
return x*+y*+s;
} void spfa(int Set){
while(!Q.empty()){
int x=Q.front().x,y=Q.front().y; Q.pop();
vis[x][y]=;
rep(i,){
int tx=x+fx[i],ty=y+fy[i];
if (tx< || ty< || tx>n || ty>m) continue; if (f[tx][ty][Set]>f[x][y][Set]+a[tx][ty]){
f[tx][ty][Set]=f[x][y][Set]+a[tx][ty];
pre[tx][ty][Set]=pack(x,y,Set);
if (!vis[tx][ty]) Q.push((node){tx,ty}),vis[tx][ty]=;
}
}
}
} void dfs(int i,int j,int Set){
if (pre[i][j][Set]==INF || pre[i][j][Set]%==)return;
vis[i][j]=;
int x=pre[i][j][Set]/,
y=(pre[i][j][Set]-x*)/,
z=(pre[i][j][Set]-x*-y*);
#ifdef debug
printf("%d,%d,%d----->%d,%d,%d\n",x,y,z,i,j,Set);
#endif
dfs(x,y,z);
if (x==i && y==j) dfs(i,j,Set-z);
} void solve(){
for(int Set=;Set<(<<cnt);Set++){
F(x,,n) F(y,,m){
for(int s=Set&(Set-);s;s=(s-)&Set){
if(f[x][y][Set]>f[x][y][s]+f[x][y][Set-s]-a[x][y]){
f[x][y][Set]=f[x][y][s]+f[x][y][Set-s]-a[x][y];
pre[x][y][Set]=pack(x,y,s);
}
}
if (f[x][y][Set]!=INF){Q.push((node){x,y}); vis[x][y]=;}
}
spfa(Set);
}
int x,y;
F(i,,n) F(j,,m) if (!a[i][j]) {x=i; y=j;break;}
printf("%d\n",f[x][y][(<<cnt)-]); #ifdef debug
F(i,,n) F(j,,m)
F(k,,(<<cnt)-)
if (pre[i][j][k]!=INF)
printf("pre[%d][%d][%d]=%d\n",i,j,k,pre[i][j][k]);
#endif
dfs(x,y,(<<cnt)-);
F(i,,n) F(j,,m){
if (!a[i][j]) putchar('x');
else if(vis[i][j]) putchar('o');
else putchar('_');
if (j==m) puts("");
}
} int main(){
#ifndef ONLINE_JUDGE
freopen("file.in","r",stdin);
// freopen("file.out","w",stdout);
#endif
scanf("%d%d",&n,&m);
F(i,,) F(j,,)
F(k,,(<<)) f[i][j][k]=pre[i][j][k]=INF;
F(i,,n)
F(j,,m){
scanf("%d",&a[i][j]);
if (!a[i][j])
f[i][j][<<(cnt++)]=;
}
solve();
return ;
}
【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 ...
- 【BZOJ】2595: [Wc2008]游览计划
题意 \(n * m\)的网格,如果\(a_{i, j} = 0\)则表示景点,否则表示这里的需要的志愿者人数.求一种安排志愿者的方案使得所有景点连通且志愿者最少. 分析 本题可以插头dp,然而有一个 ...
- 【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 ...
随机推荐
- 浅谈jvm
1 .说起jvm,很多人感觉jvm离我们开发实际很远.但是,我们开发缺每时每刻都离不开jvm. a: java源码 编译后成.class字节码文件, b:根据classpath找到这个字节码文件, c ...
- Codeforces Round #441 (Div. 2, by Moscow Team Olympiad) F. High Cry(思维 统计)
F. High Cry time limit per test 1 second memory limit per test 512 megabytes input standard input ou ...
- django项目添加新的app
- springboot中使用JOIN实现关联表查询
* 首先要确保你的表和想要关联的表有外键连接 repository中添加接口JpaSpecificationExecutor<?>,就可以使用springboot jpa 提供的API了. ...
- JSOI2018R2题解
D1T1:潜入行动 裸的树上DP.f[i][j][0/1][0/1]表示以i为根的子树放j个设备,根有没有放,根有没有被子树监听,的方案数.转移显然. #include<cstdio> # ...
- Codeforces Round #357 (Div. 2) D. Gifts by the List 水题
D. Gifts by the List 题目连接: http://www.codeforces.com/contest/681/problem/D Description Sasha lives i ...
- URAL 1881 Long problem statement
1881. Long problem statement Time limit: 0.5 secondMemory limit: 64 MB While Fedya was writing the s ...
- ROS知识(6)----卸载ROS系统
步骤方法: 1.首先卸载包 sudo apt-get purge ros-* 2.然后卸载依赖包 sudo apt-get autoremove
- SlickSafe.NET 开源权限框架开发指南
前言:本文适用于快速搭建权限系统的用户,尤其适用于希望有良好定义的权限模型建立:系统解决方案是在基于角色访问控制(RBAC)策略基础上的权限访问模型实现,主要完成了后台权限验证逻辑和前端权限数据验证的 ...
- HDU 4709 Herding (枚举)
Herding Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Sub ...