luogu P4294 [WC2008]游览计划
LINK:游览计划
斯坦纳树例题。
斯坦纳树是这样一类问题:带权无向图上有K个关键点 求出包含这K个点的最小生成树。
也就是说 求最小生成树 但是 并不是整张图 仅限于K个点。
可以发现我们利用克鲁斯卡尔或者prim算法 求的都是整张图的最小生成树。
所以可以发现 这个斯坦纳树问题 其实是一个np困难问题 不存在多项式的时间复杂度。
可以考虑搜索或者状压了。
这道题共有100个点 其中有10个关键点 我们首选状压dp.
有状态 f[i][j][k]表示到了(i,j)这个点了 所经过的点集为k的最小代价。
可以发现我们的i,j 这个点可以先往左再往右走 什么的所以有一个比较显然的转移。
f[i][j][k]=min{f[i][j][s]+f[i][j][s^k]-val[i][j]};
还有一个转移 如果当前点 跑到其他地方了f[x][y][k]=min{f[i][j][k]+val[x][y]};
两个转移就完了。其中第一个状态转移方程 我们可以直接枚举子集来做。
第二个考虑跑spfa来进行迭代dp.
可以发现是可以跑dij 可能dij在稀疏图中并不优秀?我觉着没有spfa快。
const int MAXN=11;
int n,m,cnt,l,r;
int f[MAXN][MAXN][1<<10];
int a[MAXN][MAXN],vis[MAXN][MAXN];
pii pre[MAXN][MAXN][1<<10];
pii q[10010];
int dx[5]={0,0,0,1,-1};
int dy[5]={0,1,-1,0,0};
inline void spfa(int s)
{
while(++l<=r)
{
pii w=q[l];vis[w.F][w.S]=0;
rep(1,4,i)
{
int xx=w.F+dx[i];
int yy=w.S+dy[i];
if(xx<1||yy<1||xx>n||yy>m)continue;
if(f[xx][yy][s]>f[w.F][w.S][s]+a[xx][yy])
{
f[xx][yy][s]=f[w.F][w.S][s]+a[xx][yy];
pre[xx][yy][s]=w;
if(!vis[xx][yy])vis[xx][yy]=1,q[++r]=mk(xx,yy);
}
}
}
}
inline void get_path(int x,int y,int s)
{
vis[x][y]=1;
pii w=pre[x][y][s];
if(!w.F&&!w.S)return;
if(!w.F)get_path(x,y,w.S),get_path(x,y,w.S^s);
else get_path(w.F,w.S,s);
}
int main()
{
freopen("1.in","r",stdin);
memset(f,0x3f,sizeof(f));
get(n);get(m);int s1,s2;
rep(1,n,i)rep(1,m,j)
{
get(a[i][j]);
if(!a[i][j])s1=i,s2=j,++cnt,f[i][j][1<<(cnt-1)]=0;
}
int maxx=(1<<cnt)-1;
rep(1,maxx,i)
{
l=r=0;
for(int x=1;x<=n;++x)
for(int y=1;y<=m;++y)
{
for(int s=i;s;s=i&(s-1))
if(f[x][y][s]+f[x][y][s^i]-a[x][y]<f[x][y][i])
f[x][y][i]=f[x][y][s]+f[x][y][s^i]-a[x][y],pre[x][y][i]=mk(0,s);
if(f[x][y][i]<INF)
{
q[++r]=mk(x,y);
vis[x][y]=1;
}
}
spfa(i);
}
put(f[s1][s2][maxx]);
get_path(s1,s2,maxx);
rep(1,n,i)
{
rep(1,m,j)
{
if(!a[i][j])putchar('x');
else putchar(vis[i][j]?'o':'_');
}
puts("");
}
return 0;
}
luogu P4294 [WC2008]游览计划的更多相关文章
- bzoj2595 / P4294 [WC2008]游览计划
P4294 [WC2008]游览计划 斯坦纳树 斯坦纳树,是一种神奇的树.它支持在一个连通图上求包含若干个选定点的最小生成树. 前置算法:spfa+状压dp+dfs(大雾) 我们设$f[o][P]$为 ...
- Luogu 4294 [WC2008]游览计划 | 斯坦纳树
题目链接 Luogu 4294 (我做这道题的时候BZOJ全站的SPJ都炸了 提交秒WA 幸好有洛谷) 题解 这道题是[斯坦纳树]的经典例题.斯坦纳树是这样一类问题:带边权无向图上有几个(一般约10个 ...
- 洛谷 P4294 [WC2008]游览计划
题目链接 不是很会呢,但似乎抄了题解后有点明白了 sol:状态DP显然,其实是要构建一棵最小生成树一样的东西,我自己的理解(可能不是很对哦希望多多指教)f[x][y][zt]就是到x,y这个点,状态为 ...
- P4294 [WC2008]游览计划
传送门 斯坦纳树 给一个联通图,求 $k$ 个关键点联通的最小生成树权值 设 $f[o][i]$ 表示当前关键点选择状态为 $o$ ,以点 $i$ 为根的树的最小权值 初始 $f[1<<( ...
- P4294 [WC2008]游览计划 (斯坦纳树)
题目链接 差不多是斯坦纳树裸题,不过边权化成了点权,这样在合并两棵子树时需要去掉根结点的权值,防止重复. 题目还要求输出解,只要在转移时记录下路径,然后dfs一遍就好了. #include<bi ...
- BZOJ_2595_[Wc2008]游览计划_斯坦纳树
BZOJ_2595_[Wc2008]游览计划_斯坦纳树 题意: 分析: 斯坦纳树裸题,有几个需要注意的地方 给出矩阵,不用自己建图,但枚举子集转移时会算两遍,需要减去当前点的权值 方案记录比较麻烦,两 ...
- [WC2008]游览计划 解题报告
[WC2008]游览计划 斯坦纳树板子题,其实就是状压dp 令\(dp_{i,s}\)表示任意点\(i\)联通关键点集合\(s\)的最小代价 然后有转移 \[ dp_{i,S}=\min_{T\in ...
- 【BZOJ2595】 [Wc2008]游览计划
BZOJ2595 [Wc2008]游览计划 Solution 考虑这是一个最小费用连通性的问题,既然大家都说这是什么斯坦纳树那就是的吧... 所以我们肯定可以这样设一个dp状态: \(dp_{i,j, ...
- 【BZOJ2595】[Wc2008]游览计划 斯坦纳树
[BZOJ2595][Wc2008]游览计划 Description Input 第一行有两个整数,N和 M,描述方块的数目. 接下来 N行, 每行有 M 个非负整数, 如果该整数为 0, 则该方块为 ...
随机推荐
- 「疫期集训day8」 雪原
可恶的红军,他们嘴上说着以人民为中心,被地里烧杀强掠同族人----为我们祝福吧,伟大的母亲河,为了沙皇------窝瓦河(伏尔加河)中坚守的俄罗斯白军 又是考爆的一天,然俄前两题都该A的.T1签到题一 ...
- Canonical通过Flutter启用Linux桌面应用程序支持
子标题:Ubuntu团队为所有Linux发行版上的Flutter应用程序制作了一个新的基于GTK +的主机. 此文翻译自:https://medium.com/flutter/announcing-f ...
- [网鼎杯 2020 青龙组]AreUSerialz
题目分析 <?php include("flag.php"); highlight_file(FILE); class FileHandler { protected $op ...
- PHP基础:(常量变量,数据类型,类型转换)
预定义变量(系统变量) $_GET:get方式提交的数据 $_POST:post方式提交的数据 $_REQUEST:$_GET,$_POST数据综合 $GLOBALS:PHP中所有的全局变量 $_SE ...
- Spring的学习与实战(续)
@ 目录 背景 JavaMailSender Spring集成邮件发送功能 1. 添加maven依赖 2. 添加Spring邮件配置 3. 创建邮件管理Bean并注入Spring应用上下文 4. 修改 ...
- Python Ethical Hacking - BACKDOORS(7)
Handling Errors: If the client or server crashes, the connection will be lost. Backdoor crashes if: ...
- Python Ethical Hacking - WEB PENETRATION TESTING(4)
CRAWING SPIDER Goal -> Recursively list all links starting from a base URL. 1. Read page HTML. 2. ...
- 【NET开发】图片处理类-仿照七牛云图片处理功能
介绍 Sop.Common.Img **请看 七牛云的图片处理功能介绍文档了解本项目功能 ** 此项目是有https://github.com/Sopcce/.Net-Common-Utility中的 ...
- WYT的刷子
WYT的刷子 题目描述 WYT有一把巨大的刷子,刷子的宽度为M米,现在WYT要使用这把大刷子去粉刷有N列的栅栏(每列宽度都为1米:每列的高度单位也为米,由输入数据给出). 使用刷子的规则是: 与地面垂 ...
- 入门大数据---Hive计算引擎Tez简介和使用
一.前言 Hive默认计算引擎时MR,为了提高计算速度,我们可以改为Tez引擎.至于为什么提高了计算速度,可以参考下图: 用Hive直接编写MR程序,假设有四个有依赖关系的MR作业,上图中,绿色是Re ...