[bzoj4006][斯坦纳树][DP]管道连接

2023-10-16 03:18

本文主要是介绍[bzoj4006][斯坦纳树][DP]管道连接,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Description

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

该部门有 n 个情报站,用 1 到 n 的整数编号。给出 m 对情报站 ui;vi 和费用 wi,表示情 报站 ui 和 vi 之间可以花费
wi 单位资源建立通道。 如果一个情报站经过若干个建立好的通道可以到达另外一个情报站,那么这两个情报站就 建立了通道连接。形式化地,若 ui
和 vi 建立了通道,那么它们建立了通道连接;若 ui 和 vi 均 与 ti 建立了通道连接,那么 ui 和 vi 也建立了通道连接。
现在在所有的情报站中,有 p 个重要情报站,其中每个情报站有一个特定的频道。小铭铭
面临的问题是,需要花费最少的资源,使得任意相同频道的情报站之间都建立通道连接。

Input

第一行包含三个整数 n;m;p,表示情报站的数量,可以建立的通道数量和重要情报站的数

量。接下来 m 行,每行包含三个整数 ui;vi;wi,表示可以建立的通道。最后有 p 行,每行包含 两个整数
ci;di,表示重要情报站的频道和情报站的编号。

Output

输出一行一个整数,表示任意相同频道的情报站之间都建立通道连接所花费的最少资源总量。

Sample Input

5 8 4

1 2 3

1 3 2

1 5 1

2 4 2

2 5 1

3 4 3

3 5 1

4 5 1

1 1

1 2

2 3

2 4

Sample Output

4

HINT

选择 (1; 5); (3; 5); (2; 5); (4; 5) 这 4 对情报站连接。

对于 100% 的数据,0 <ci <= p <= 10; 0 <ui;vi;di <= n <= 1000; 0 <= m <=
3000; 0 <= wi <=

20000。

题解

不考虑频道的情况显然是一个斯坦纳树
考虑的话就先做一遍斯坦纳树
求出一个 s u m [ i ] sum[i] sum[i]表示 i i i状态下的点联通最小需要多少花费
然后设一个 f [ i ] f[i] f[i]表示 i i i状态下的所有点都被选好了的最小花费
枚举一下子集转移就好了
可以预处理一个 o k [ i ] ok[i] ok[i]表示 i i i状态下的这些点能不能合法存在于同一个斯坦纳树中

#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<algorithm>
#include<cmath>
#include<queue>
#include<vector>
#include<ctime>
#include<map>
#include<bitset>
#include<set>
#define LL long long
#define mp(x,y) make_pair(x,y)
#define pll pair<long long,long long>
#define pii pair<int,int>
using namespace std;
inline int read()
{int f=1,x=0;char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}return x*f;
}
int stack[20];
inline void write(LL x)
{if(x<0){putchar('-');x=-x;}if(!x){putchar('0');return;}int top=0;while(x)stack[++top]=x%10,x/=10;while(top)putchar(stack[top--]+'0');
}
inline void pr1(int x){write(x);putchar(' ');}
inline void pr2(LL x){write(x);putchar('\n');}
const int MAXMASK=(1<<10);
const int MAXN=1005;
const int MAXM=3005;
struct node{int x,y,c,next;}a[2*MAXM];int len,last[MAXN];
void ins(int x,int y,int c){len++;a[len].x=x;a[len].y=y;a[len].c=c;a[len].next=last[x];last[x]=len;}queue<int> li;
bool v[MAXN];
int dp[MAXN][MAXMASK];
void spfa(int S)
{while(!li.empty()){int x=li.front();li.pop();v[x]=false;for(int k=last[x];k;k=a[k].next){int y=a[k].y;if(dp[y][S]>dp[x][S]+a[k].c){dp[y][S]=dp[x][S]+a[k].c;if(!v[y])v[y]=true,li.push(y);}}}
}
int bin[25],n,m,P;
int u1[MAXN],u2[MAXN];
void go()
{memset(dp,63,sizeof(dp));int inf=dp[0][0];for(int i=1;i<=P;i++)dp[u2[i]][bin[i]]=0;for(int S=1;S<bin[P+1];S++){for(int i=1;i<=n;i++){for(int j=(S-1)&S;j;j=(j-1)&S)dp[i][S]=min(dp[i][S],dp[i][j]+dp[i][S^j]);if(dp[i][S]!=inf)v[i]=true,li.push(i);}spfa(S);}
}
int sum[MAXMASK];
int num[15],ok[MAXMASK];
int f[MAXMASK];
int main()
{
//	freopen("1.in","r",stdin);bin[1]=1;for(int i=2;i<=20;i++)bin[i]=bin[i-1]<<1;n=read();m=read();P=read();for(int i=1;i<=m;i++){int x=read(),y=read(),c=read();ins(x,y,c);ins(y,x,c);}for(int i=1;i<=P;i++){u1[i]=read(),u2[i]=read();num[u1[i]]|=bin[i];}for(int i=0;i<bin[P+1];i++){ok[i]=1;for(int j=1;j<=P;j++)if(i&bin[j]){if((i&num[u1[j]])!=num[u1[j]]){ok[i]=0;break;}}}go();memset(sum,63,sizeof(sum));for(int i=0;i<bin[P+1];i++)for(int j=1;j<=n;j++)sum[i]=min(sum[i],dp[j][i]);memset(f,63,sizeof(f));f[0]=0;for(int i=1;i<bin[P+1];i++){if(ok[i])f[i]=min(f[i],sum[i]);for(int j=(i-1)&i;j;j=(j-1)&i)if(ok[j])f[i]=min(f[i],sum[j]+f[i^j]);}pr2(f[bin[P+1]-1]);return 0;
}

这篇关于[bzoj4006][斯坦纳树][DP]管道连接的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/218643

相关文章

VScode连接远程Linux服务器环境配置图文教程

《VScode连接远程Linux服务器环境配置图文教程》:本文主要介绍如何安装和配置VSCode,包括安装步骤、环境配置(如汉化包、远程SSH连接)、语言包安装(如C/C++插件)等,文中给出了详... 目录一、安装vscode二、环境配置1.中文汉化包2.安装remote-ssh,用于远程连接2.1安装2

关于rpc长连接与短连接的思考记录

《关于rpc长连接与短连接的思考记录》文章总结了RPC项目中长连接和短连接的处理方式,包括RPC和HTTP的长连接与短连接的区别、TCP的保活机制、客户端与服务器的连接模式及其利弊分析,文章强调了在实... 目录rpc项目中的长连接与短连接的思考什么是rpc项目中的长连接和短连接与tcp和http的长连接短

Xshell远程连接失败以及解决方案

《Xshell远程连接失败以及解决方案》本文介绍了在Windows11家庭版和CentOS系统中解决Xshell无法连接远程服务器问题的步骤,在Windows11家庭版中,需要通过设置添加SSH功能并... 目录一.问题描述二.原因分析及解决办法2.1添加ssh功能2.2 在Windows中开启ssh服务2

Redis连接失败:客户端IP不在白名单中的问题分析与解决方案

《Redis连接失败:客户端IP不在白名单中的问题分析与解决方案》在现代分布式系统中,Redis作为一种高性能的内存数据库,被广泛应用于缓存、消息队列、会话存储等场景,然而,在实际使用过程中,我们可能... 目录一、问题背景二、错误分析1. 错误信息解读2. 根本原因三、解决方案1. 将客户端IP添加到Re

Mysql 中的多表连接和连接类型详解

《Mysql中的多表连接和连接类型详解》这篇文章详细介绍了MySQL中的多表连接及其各种类型,包括内连接、左连接、右连接、全外连接、自连接和交叉连接,通过这些连接方式,可以将分散在不同表中的相关数据... 目录什么是多表连接?1. 内连接(INNER JOIN)2. 左连接(LEFT JOIN 或 LEFT

Spring Boot实现多数据源连接和切换的解决方案

《SpringBoot实现多数据源连接和切换的解决方案》文章介绍了在SpringBoot中实现多数据源连接和切换的几种方案,并详细描述了一个使用AbstractRoutingDataSource的实... 目录前言一、多数据源配置与切换方案二、实现步骤总结前言在 Spring Boot 中实现多数据源连接

QT实现TCP客户端自动连接

《QT实现TCP客户端自动连接》这篇文章主要为大家详细介绍了QT中一个TCP客户端自动连接的测试模型,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录版本 1:没有取消按钮 测试效果测试代码版本 2:有取消按钮测试效果测试代码版本 1:没有取消按钮 测试效果缺陷:无法手动停

W外链微信推广短连接怎么做?

制作微信推广链接的难点分析 一、内容创作难度 制作微信推广链接时,首先需要创作有吸引力的内容。这不仅要求内容本身有趣、有价值,还要能够激起人们的分享欲望。对于许多企业和个人来说,尤其是那些缺乏创意和写作能力的人来说,这是制作微信推广链接的一大难点。 二、精准定位难度 微信用户群体庞大,不同用户的需求和兴趣各异。因此,制作推广链接时需要精准定位目标受众,以便更有效地吸引他们点击并分享链接

hdu4826(三维DP)

这是一个百度之星的资格赛第四题 题目链接:http://acm.hdu.edu.cn/contests/contest_showproblem.php?pid=1004&cid=500 题意:从左上角的点到右上角的点,每个点只能走一遍,走的方向有三个:向上,向下,向右,求最大值。 咋一看像搜索题,先暴搜,TLE,然后剪枝,还是TLE.然后我就改方法,用DP来做,这题和普通dp相比,多个个向上

hdu1011(背包树形DP)

没有完全理解这题, m个人,攻打一个map,map的入口是1,在攻打某个结点之前要先攻打其他一个结点 dp[i][j]表示m个人攻打以第i个结点为根节点的子树得到的最优解 状态转移dp[i][ j ] = max(dp[i][j], dp[i][k]+dp[t][j-k]),其中t是i结点的子节点 代码如下: #include<iostream>#include<algorithm