BZOJ_4006_[JLOI2015]管道连接_斯坦纳树

题意:

小铭铭最近进入了某情报部门,该部门正在被如何建立安全的通道连接困扰。

该部门有 n 个情报站,用 1 到 n 的整数编号。给出 m 对情报站 ui;vi 和费用 wi,表示情
报站 ui 和 vi 之间可以花费 wi 单位资源建立通道。
如果一个情报站经过若干个建立好的通道可以到达另外一个情报站,那么这两个情报站就
建立了通道连接。形式化地,若 ui 和 vi 建立了通道,那么它们建立了通道连接;若 ui 和 vi 均
与 ti 建立了通道连接,那么 ui 和 vi 也建立了通道连接。
现在在所有的情报站中,有 p 个重要情报站,其中每个情报站有一个特定的频道。小铭铭
面临的问题是,需要花费最少的资源,使得任意相同频道的情报站之间都建立通道连接。
 
分析:
先求一遍原图的斯坦纳树,处理出每个连通状态下的最小花费
但我们发现所求的方案并不一定是所有关键点都连通
再处理出每个频道需要情报站的状态
要进行状态之间的合并
DP g[i] = min(g[i], g[j] + g[i^j])
 
思路同BZOJ_4774
 
代码:
#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std;
#define N 1050
#define M 6050
int head[N],to[M],nxt[M],val[M],n,m,p,cnt,inq[N];
int dis[1025][N],Q[N],l,r,d[11],s[11];
int f[1025],g[1025],mask,tnl,is[11];
inline void add(int u,int v,int w){
to[++cnt]=v;nxt[cnt]=head[u];head[u]=cnt;val[cnt]=w;
}
struct A{
int id,num,rnum;
}b[11];
bool cmp1(const A &x,const A &y){
return x.rnum<y.rnum;
}
bool cmp2(const A &x,const A &y){
return x.id<y.id;
}
void stan(){
int i,j,k;
memset(dis,0x3f,sizeof(dis));
for(i=1;i<=p;i++){
dis[1<<i-1][d[i]]=0;
}
for(j=1;j<=mask;j++){
for(i=1;i<=n;i++){
for(k=j&(j-1);k;k=j&(k-1)){
dis[j][i]=min(dis[j][i],dis[k][i]+dis[j-k][i]);
}
}
l=r=0;
for(i=1;i<=n;i++){
Q[r++]=i;inq[i]=1;
}
while(l^r){
int x=Q[l++];inq[x]=0;if(l==n+1)l=0;
for(k=head[x];k;k=nxt[k]){
if(dis[j][to[k]]>dis[j][x]+val[k]){
dis[j][to[k]]=dis[j][x]+val[k];
if(!inq[to[k]]){
inq[to[k]]=1;Q[r++]=to[k];if(r==n+1)r=0;
}
}
}
}
}
}
int main(){
scanf("%d%d%d",&n,&m,&p);
mask=(1<<p)-1;
int i,j,x,y,z,k;
for(i=1;i<=m;i++){
scanf("%d%d%d",&x,&y,&z);
add(x,y,z);add(y,x,z);
}
for(i=1;i<=p;i++){
scanf("%d%d",&b[i].rnum,&d[i]);
b[i].id=i;
}
sort(b+1,b+p+1,cmp1);
b[0].rnum=-10000;
for(i=1;i<=p;i++){
if(b[i].rnum==b[i-1].rnum){
b[i].num=b[i-1].num;
}else b[i].num= ++tnl;
}
sort(b+1,b+p+1,cmp2);
for(i=1;i<=p;i++){
s[b[i].num]|=(1<<i-1);
}
stan();
memset(f,0x3f,sizeof(f));
memset(g,0x3f,sizeof(g));
for(i=0;i<=mask;i++){
for(j=1;j<=n;j++){
f[i]=min(f[i],dis[i][j]);
}
}
for(i=0;i<=mask;i++){
k=0;
for(j=1;j<=p;j++){
if(i&(1<<j-1)){
k|=s[b[j].num];
}
}
g[i]=f[k];
}
for(i=0;i<=mask;i++){
for(j=i&(i-1);j;j=i&(j-1)){
g[i]=min(g[i],g[j]+g[i-j]);
}
}
printf("%d\n",g[mask]);
}

BZOJ_4006_[JLOI2015]管道连接_斯坦纳树的更多相关文章

  1. [bzoj4006][JLOI2015]管道连接_斯坦纳树_状压dp

    管道连接 bzoj-4006 JLOI-2015 题目大意:给定一张$n$个节点$m$条边的带边权无向图.并且给定$p$个重要节点,每个重要节点都有一个颜色.求一个边权和最小的边集使得颜色相同的重要节 ...

  2. bzoj 4006 [JLOI2015]管道连接(斯坦纳树+状压DP)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=4006 [题意] 给定n点m边的图,连接边(u,v)需要花费w,问满足使k个点中同颜色的 ...

  3. BZOJ 4006 [JLOI2015]管道连接(斯坦纳树+子集DP)

    明显是一道斯坦纳树的题. 然而这题只需要属性相同的点互相连接. 我们还是照常先套路求出\(ans[s]\). 然后对\(ans[s]\)做子集DP即可. 具体看代码. #include<iost ...

  4. 【bzoj4006】[JLOI2015]管道连接(斯坦纳树+dp)

    题目链接 题意: 给出\(n\)个点,\(m\)条边,同时给出\(p\)个重要的点以及对应特征. 现在要选出一些边,问使得这\(p\)个所有特征相同的点相连,问最小代价. 思路: 斯坦纳树的应用场景一 ...

  5. 洛谷P3264 [JLOI2015]管道连接(斯坦纳树)

    传送门 感觉对斯坦纳树还是有很多疑惑啊…… 等到时候noip没有爆零的话再回来填坑好了 //minamoto #include<iostream> #include<cstdio&g ...

  6. [JLOI2015]管道连接(斯坦纳树)

    [Luogu3264] 原题解 多个频道,每个频道的关键点要求相互联通 详见代码,非常巧妙 #include<cstdio> #include<iostream> #inclu ...

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

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

  8. BZOJ4006 JLOI2015 管道连接(斯坦纳树生成森林)

    4006: [JLOI2015]管道连接 Time Limit: 30 Sec Memory Limit: 128 MB Description 小铭铭最近进入了某情报部门,该部门正在被如何建立安全的 ...

  9. [BZOJ4006][JLOI2015]管道连接 状压dp+斯坦纳树

    4006: [JLOI2015]管道连接 Time Limit: 30 Sec  Memory Limit: 128 MBSubmit: 1020  Solved: 552[Submit][Statu ...

随机推荐

  1. mysql之数据库的增删改查

    一.DDL 1.创建数据库 create database 数据库名 *数据库名不能中文, 不能数字正常英文 , 关键字会自动变大写 2.删除数据库 drop database 数据库名 3.使用数据 ...

  2. contentType,charset和pageEncoding的区别

    简单点总结就是jsp页面头上这样写  <%@ page contentType="text/html;charset=GBK" %> 页面用GBK编码 pageEnco ...

  3. java队列

    "队列"这个单词是英国人说的"排".在英国"排队"的意思就是站到一排当中去.计算机科学中,队列是一种数据结构,有点类似栈,只是在队列中第一个 ...

  4. 框架学习:ibatis框架的结构和分析

    由于最近一段时间比较忙碌,<框架学习>系列的文章一直在搁浅着,最近开始继续这个系列的文章更新. 在上篇文章中我们说到了hibernate框架,它是一种基于JDBC的主流持久化框架,是一个优 ...

  5. 新装的主机没有ifconfig,route等命令,怎么查找对应的安装包

    公司最近有台新装的主机,主机上一些常用的命令都没有,比如说ifconfig,route等命令. 没有这些命令主机很难工作,所以我们就需要把他安装上 第一种方法:是你需要知道对应的是那个包 比如说ifc ...

  6. vue-cli目录结构

  7. 【转】学习FFmpeg API – 解码视频

    ffmpeg是编解码的利器,用了很久,以前看过dranger 的教程,非常精彩,受益颇多,是学习ffmpeg api很好的材料.可惜的是其针对的ffmpeg版本已经比较老了,而ffmpeg的更新又很快 ...

  8. linux下面调试C、C++

    (1)写好makefile文件(支持debug) objects = Main.o Satellite.o TimeSystem.o  SRPPara:$(objects) g++ -g -o SRP ...

  9. es6(二):解构赋值

    ES中允许按照一定格式从数组,对象值提取值,对变量进行赋值,这就是解构(Destructuring) let [a,b,c]=[1,10,100] console.log(a,b,c)//1 10 1 ...

  10. 阿里服务器CentOS报错base ls command not found

    第一次linux中安装jdk时,踩过的坑. 1.vi command not found ,输入任何命令都无法实现 只要原因是因为环境变量的问题,编辑profile文件没有写正确,导致在命令行下 ls ...