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】游览计划的更多相关文章

  1. bzoj 2595 [Wc2008]游览计划(斯坦纳树)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2595 [题意] 给定N*M的长方形,选最少权值和的格子使得要求的K个点连通. [科普] ...

  2. bzoj:2595: [Wc2008]游览计划

    Description Input 第一行有两个整数,N和 M,描述方块的数目. 接下来 N行, 每行有 M 个非负整数, 如果该整数为 0, 则该方块为一个景点:否则表示控制该方块至少需要的志愿者数 ...

  3. BZOJ 2595: [Wc2008]游览计划 [DP 状压 斯坦纳树 spfa]【学习笔记】

    传送门 题意:略 论文 <SPFA算法的优化及应用> http://www.cnblogs.com/lazycal/p/bzoj-2595.html 本题的核心就是求斯坦纳树: Stein ...

  4. BZOJ.2595.[WC2008]游览计划(DP 斯坦纳树)

    题目链接 f[i][s]表示以i为根节点,当前关键点的连通状态为s(每个点是否已与i连通)时的最优解.i是枚举得到的根节点,有了根节点就容易DP了. 那么i为根节点时,其状态s的更新为 \(f[i][ ...

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

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

  6. 【BZOJ 2595】2595: [Wc2008]游览计划 (状压DP+spfa,斯坦纳树?)

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

  7. 【BZOJ】2595: [Wc2008]游览计划

    题意 \(n * m\)的网格,如果\(a_{i, j} = 0\)则表示景点,否则表示这里的需要的志愿者人数.求一种安排志愿者的方案使得所有景点连通且志愿者最少. 分析 本题可以插头dp,然而有一个 ...

  8. 【LG4294】[WC2008]游览计划

    [LG4294][WC2008]游览计划 题面 洛谷 bzoj 题解 斯坦纳树板子题. 斯坦纳树的总结先留个坑. 代码 #include <iostream> #include <c ...

  9. BZOJ_2595_[Wc2008]游览计划_斯坦纳树

    BZOJ_2595_[Wc2008]游览计划_斯坦纳树 题意: 分析: 斯坦纳树裸题,有几个需要注意的地方 给出矩阵,不用自己建图,但枚举子集转移时会算两遍,需要减去当前点的权值 方案记录比较麻烦,两 ...

  10. [WC2008]游览计划 解题报告

    [WC2008]游览计划 斯坦纳树板子题,其实就是状压dp 令\(dp_{i,s}\)表示任意点\(i\)联通关键点集合\(s\)的最小代价 然后有转移 \[ dp_{i,S}=\min_{T\in ...

随机推荐

  1. 【Codeforces】113 D. Museum

    题解 我们设\(f(i,j)\)是\((i,j)\)这个点期望被经过多少次 我们可以列出方程组来消元,由于终点只会被经过0次或者1次,期望就是概率 对于起点的话我们期望经过次数多加一个1 复杂度\(O ...

  2. POJ - 3111 K Best 0-1分数规划 二分

    K Best Time Limit: 8000MS   Memory Limit: 65536K Total Submissions: 12812   Accepted: 3290 Case Time ...

  3. 手动制作用于启动BeagleBoneBlack(am335x)的SD

    1.需求MLO.u-boot.img.uImage.Systemfile 获取MLO.u-boot.img下载U-boot源码,解压获得源码,进入源码目录 cd /home/zyr/Source_co ...

  4. 【基础知识】winfrom窗体的属性

    窗体的属性: Icon:窗体的右上角图标 FormBoarderStyle:窗体的边线样式 MaximizeBox: 最大化按钮是否可用 MinimizeBox:最小化按钮是否可用 Opacity:透 ...

  5. iOS 9应用开发教程之创建iOS 9项目与模拟器介绍

    iOS 9应用开发教程之创建iOS 9项目与模拟器介绍 编写第一个iOS 9应用 本节将以一个iOS 9应用程序为例,为开发者讲解如何使用Xcode 7.0去创建项目,以及iOS模拟器的一些功能.编辑 ...

  6. LOJ P3960 列队 树状数组 vector

    https://www.luogu.org/problemnew/show/P3960 树状数组预处理之后直接搞就可以了,也不是很好解释,反正就是一个模拟过程的暴力用树状数组维护,还挺巧妙的. 我为什 ...

  7. [Agc002E]Candy Piles

    [Agc002E]Candy Piles 题目大意 有\(n\)个数,两人轮流操作,可以做以下操作之一: 删掉一个最大的数 将所有数-1 最后取没的人输,问先手是否必胜? 试题分析 直接决策不知道选哪 ...

  8. 【BFS】【最小生成树】Petrozavodsk Winter Training Camp 2018 Day 1: Jagiellonian U Contest, Tuesday, January 30, 2018 Problem G. We Need More Managers!

    题意:给你n个点,点带权,任意两点之间的边权是它们的点权的异或值中“1”的个数,问你该图的最小生成树. 看似是个完全图,实际上有很多边是废的.类似……卡诺图的思想?从读入的点出发BFS,每次只到改变它 ...

  9. 课堂练习—hash

    课堂练习-hash 要求: 利用除留余数法为下列关键字集合的存储设计hash函数,并画出分别用开放寻址法和拉链法解决冲突得到的空间存储状态(散列因子取0.75) 关键字集合:85,75,57,60,6 ...

  10. 构造Huffman以及实现

    构造Huffman 题目 在作业本上分别针对权值集合W=(6,5,3,4,60,18,77)和W=(7,2,4,5,8)构造哈夫曼树,提交构造过程的照片 错误回答 错误原因:遵循左边小于根右边大于根的 ...