HDU 4085 斯坦纳树+DP
https://cn.vjudge.net/problem/HDU-4085
给你n,m,k ,分别表示有n个点,m条边,每条边有一个权值,表示修复这条边需要的代价
从前k个点中任取一个使其和后k个点中的某一个点,通过边连接,并且必须是一一对应,问最小的代价是多少。
先用斯坦纳树模板求出f[i][1<<k] 然后用dp[i]表示所有点为根的情况下连通状态为i的最小花费
这样我们就可以从1dp到1<<k得到答案 注意dp之前要先判总状态是否合法 再判子集是否合法 最后再进行dp更新
#include<bits/stdc++.h>
#define N 6003
#define inf 1000000000
using namespace std;
int n, m, k, tot;
int point[N], next1[N], v[N], len[N];
int f[][( << )], mi[], can[N], dp[( << )];
queue<int> p;
void add(int x, int y, int z) {
tot++;
next1[tot] = point[x];
point[x] = tot;
v[tot] = y;
len[tot] = z;
tot++;
next1[tot] = point[y];
point[y] = tot;
v[tot] = x;
len[tot] = z;
}
void spfa(int sta) {
while (!p.empty()) {
int now = p.front();
p.pop();
for (int i = point[now]; i; i = next1[i]) {
if (f[v[i]][sta] > f[now][sta] + len[i]) {
f[v[i]][sta] = f[now][sta] + len[i];
if (!can[v[i]]) {
can[v[i]] = ;
p.push(v[i]);
}
}
}
can[now] = ;
}
}
bool check(int sta) { //判断当前的状态是否满足一一对应关系
int ans = ;
for (int i = ; i < k; i++) {
if (sta & ( << i))
ans++;
if (sta & ( << (i + k)))
ans--;
}
return (ans == );
}
int main() {
int t;
scanf("%d", &t);
mi[] = ;
for (int i = ; i <= ; i++)
mi[i] = mi[i - ] * ;
for (int T = ; T <= t; T++) {
scanf("%d%d%d", &n, &m, &k);
tot = ;
memset(point, , sizeof(point));
memset(next1, , sizeof(next1));
for (int i = ; i <= m; i++) {
int x, y, z;
scanf("%d%d%d", &x, &y, &z);
add(x, y, z);
}
for (int i = ; i <= n; i++)
for (int j = ; j < mi[]; j++)
f[i][j] = inf;
for (int i = ; i <= k; i++)
f[i][mi[i - ]] = ;
int t = k;
for (int i = n - k + ; i <= n; i++)
f[i][mi[t]] = , t++;
for (int sta = ; sta < mi[t]; sta++) {
for (int i = ; i <= n; i++) {
for (int s = sta & (sta - ); s; s = sta & (s - )) {
int t = f[i][sta - s] + f[i][s];
f[i][sta] = min(f[i][sta], t);
}
if (f[i][sta] != inf)
p.push(i), can[i] = ;
}
spfa(sta);
}
for (int sta = ; sta < mi[t]; sta++) {
dp[sta] = inf;
for (int i = ; i <= n; i++)
dp[sta] = min(dp[sta], f[i][sta]);
}
for (int sta = ; sta < mi[t]; sta++)
if (check(sta))
for (int s = sta & (sta - ); s; s = sta & (s - ))
if (check(s))
dp[sta] = min(dp[sta], dp[s] + dp[sta - s]);
if (dp[mi[t] - ] == inf)
printf("No solution\n");
else
printf("%d\n", dp[mi[t] - ]);
}
}
HDU 4085 斯坦纳树+DP的更多相关文章
- HDU 4085 斯坦纳树
题目大意: 给定无向图,让前k个点都能到达后k个点(保护地)中的一个,而且前k个点每个需要占据后k个中的一个,相互不冲突 找到实现这个条件达到的选择边的最小总权值 这里很容易看出,最后选到的边不保证整 ...
- hdu 3311 斯坦纳树
思路:虚拟一个0号节点,将每个点建一条到0号节点的边,权值为挖井需要的价值.并要保证0号节点同另外n个寺庙一样被选择即可. 然后就是求斯坦纳树了. #include<map> #inclu ...
- 【hdu3311】Dig The Wells(斯坦纳树+dp)
传送门 题意: 给出\(n\)个重要点,还有其余\(m\)个点,\(p\)条边. 现在要在这\(n+m\)个点中挖几口水井,每个地方的费用为\(w_i\).连接边也有费用. 问使得这\(n\)个地点都 ...
- 【bzoj4006】[JLOI2015]管道连接(斯坦纳树+dp)
题目链接 题意: 给出\(n\)个点,\(m\)条边,同时给出\(p\)个重要的点以及对应特征. 现在要选出一些边,问使得这\(p\)个所有特征相同的点相连,问最小代价. 思路: 斯坦纳树的应用场景一 ...
- [WC2008]游览计划(斯坦纳树)
[Luogu4294] 题解 : 斯坦纳树 \(dp[i][j]\) 表示以\(i\)号节点为根,当前状态为\(j\)(与\(i\)连通的点为\(1\)) 当根\(i\)不改变时状态转移方程是: \( ...
- HDU 4085 Peach Blossom Spring 斯坦纳树 状态压缩DP+SPFA
状态压缩dp+spfa解斯坦纳树 枚举子树的形态 dp[i][j] = min(dp[i][j], dp[i][k]+dp[i][l]) 当中k和l是对j的一个划分 依照边进行松弛 dp[i][j] ...
- 【BZOJ2595】游览计划(状压DP,斯坦纳树)
题意:见题面(我发现自己真是越来越懒了) 有N*M的矩阵,每个格子有一个值a[i,j] 现要求将其中的K个点(称为关键点)用格子连接起来,取(i,j)的费用就是a[i,j] 求K点全部连通的最小花费以 ...
- hdu4085 Peach Blossom Spring 斯坦纳树,状态dp
(1)集合中元素表示(1<<i), i从0开始 (2)注意dp[i][ss] = min(dp[i][ss], dp[i][rr | s[i]] + dp[i][(ss ^ rr) | s ...
- HDU 3311 Dig The Wells(斯坦纳树)
[题目链接] http://acm.hdu.edu.cn/showproblem.php?pid=3311 [题意] 给定k座庙,n个其他点,m条边,点权代表挖井费用,边权代表连边费用,问使得k座庙里 ...
随机推荐
- linux ssh利用公钥免密登陆
1.安装检查ssh 如果没有ssh的话,需要安装 #yum install -y openssh-server openssh-clients 2.生成秘钥 ssh-keygen -t rsa 执行 ...
- 【DSP开发】硬件信号量在多核处理器核间通信中的应用
硬件信号量在多核处理器核间通信中的应用 刘德保1,汪安民1,韩道文2 1.同方电子科技有限公司研究所,九江 332009:2.解放军电子工程学院 摘要: 在多核处理器的软件设计中,核间通信机制是关键所 ...
- [转帖]关于USB3.0以及type-C
忘记来源页面了.. 但是昨天晚上 usb 4.0 发布了 跟雷电C 安全一样的标准 双向40gb 的带宽. 而且 以后只有usb type-C的接口了. 我们办公机器上面的 typeC 同事用 ngf ...
- [转帖]phoronix-test-suite测试云服务器
phoronix-test-suite测试云服务器 https://www.cnblogs.com/tanyongli/p/7767804.html centos系统 phoronix-test-su ...
- SpringCloud 教程 | 终章
错过了这一篇,你可能再也学不会 Spring Cloud 了!Spring Boot做为下一代 web 框架,Spring Cloud 作为最新最火的微服务的翘楚,你还有什么理由拒绝.赶快上船吧,老船 ...
- Pygame小游戏练习五
@Python编程从入门到实践 Python项目练习 十一.显示游戏得分及最高分 创建新类Scoreboard,用以显示得分和最高分. # scoreboard.py import pygame.fo ...
- 用bisect来管理已排序的序列
bisect 模块包含两个主要函数,bisect 和 insort,两个函数都利用二分查找算法来在有序序列中查找或插入元素. 2.8.1 用bisect来搜索 bisect(haystack, nee ...
- gitlab安装指南(gitlab-ce-9.4.3-ce.0.el7.x86_64 centos7)
1,安装gitlab wget https://packages.gitlab.com/gitlab/gitlab-ce/packages/el/7/gitlab-ce-9.4.3-ce.0.el7. ...
- 第四章 MIZ701 ZYNQ制作UBOOT固化程序
4.0难度系数★☆☆☆☆☆☆ 4.1是什么是固化 我们前几章将的程序都是通过JTAG先下载bit流文件,再下载elf文件,之后点击Run As来运行的程序.JTAG的方法是通过TCL脚本来初始化P ...
- html5手机网页开发,中文输入法下软键盘遮挡输入框
安卓手机解决办法 微信UI框架weui中给出了解决方法:weui框架http://weui.github.io/weui/example.js // .container 设置了 overflow 属 ...