洛谷P3959 宝藏(NOIP2017)(状压DP,子集DP)
Dalao的题解多数是什么模拟退火、DFS剪枝、\(O(3^nn^2)\)的状压DP之类。蒟蒻尝试着把状压改进了一下使复杂度降到\(O(3^nn)\)。
考虑到每条边的贡献跟它所在的层有关,所以如果我们能够将一层的边一起加进去,计算就会方便许多。于是想办法把这个转移过程状压一下。
设\(f_{i,j}\)为当前已选点集为\(i\),下一层加入的点集为\(j\)时,新加入的所有点与原有点之间最小的边权之和。计算的具体实现,我们\(O(2^n)\)枚举\(i\),再枚举\(i\)的补集的子集\(j\),把\(j\)的\(lowbit\)挑出来,\(f_{i,j}\)等于\(f_{i,j-lowbit(j)}\)加上\(\log lowbit(j)\)与\(i\)之间的最小边权。
这一部分的复杂度是\(O(3^nn)\)(\(n\)元素集合的所有子集的子集大小之和是\(3^n\)可以证)
接着就可以开始转移了。设\(g_{l,i}\)为总层数为\(l\),已选点集为\(i\)的最小答案。参考\(f\)的定义我们可以很快的写出转移方程(式中的\(i-j\)为集合意义,代码中写i^j
)
\]
也是一遍枚举子集,复杂度还是\(O(3^nn)\)。最后\(\max\limits_{l=0}^ng_{l,2^n-1}\)就是答案。
当然,为了实际复杂度和理论一致,我们枚举子集不能这样暴枚
for(i=0;i<=S;++i)
if(i&S==i)//do something
而应该这样
for(i=S;i;i=(i-1)&S)
//do something
跟队爷Anson学的,具体原理蒟蒻也策不清楚啊qwq
代码十分简洁,注意INF的设置
#include<bits/stdc++.h>
#define R register int
using namespace std;
const int N=13,M=4096,INF=0x01010101;
int a[N][N],f[M][M],g[N][M],ne[M],lg[M];
inline void chkmn(R&x,R y){
if(x>y)x=y;
}
int main(){
memset(a,1,sizeof(a));
memset(g,63,sizeof(g));//貌似需要区别对待
R n,m,S,s,i,j,l,x,y,v;
cin>>n>>m;
S=(1<<n)-1;
for(i=0;i<n;++i)
lg[1<<i]=i;//log预处理
while(m--){
cin>>x>>y>>v;
if(a[--x][--y]>v)//邻接矩阵存边
a[x][y]=a[y][x]=v;
}
for(i=1;i<=S;++i){
v=0;
for(j=s=S^i;j;j=(j-1)&s)
ne[j]=v,v=j;//为了更新顺序需要反向枚举
for(j=v;j;j=ne[j]){
x=lg[j&-j];v=INF;
for(y=0;y<n;++y)//找到可以连接的最小边权
if(1<<y&i)chkmn(v,a[x][y]);
f[i][j]=f[i][j^(j&-j)]+v;
}
}
for(i=1;i<=S;i<<=1)
g[0][i]=0;//状态预处理
for(l=1;l<n;++l)
for(i=1;i<=S;++i)
for(j=i;j;j=(j-1)&i)
chkmn(g[l][i],g[l-1][i^j]+f[i^j][j]*l);
v=0x7fffffff;
for(l=0;l<=n;++l)
chkmn(v,g[l][S]);
cout<<v<<endl;
return 0;
}
洛谷P3959 宝藏(NOIP2017)(状压DP,子集DP)的更多相关文章
- 洛谷P3959 宝藏(状压dp)
传送门 为什么感觉状压dp都好玄学……FlashHu大佬太强啦…… 设$f_{i,j}$表示当前选的点集为$i$,下一次要加入的点集为$j$时,新加入的点和原有的点之间的最小边权.具体的转移可以枚举$ ...
- 洛谷 P3959 宝藏【状压dp】
一开始状态设计错了-- 设f[i][s]为当前与根节点联通状况为s,最深深度为i 转移的话枚举当前没有和根联通的点集,预处理出把这些点加进联通块的代价(枚举s中的点和当前点的连边乘以i即可),然后用没 ...
- 洛谷 3959 宝藏——枚举+状压dp
题目:https://www.luogu.org/problemnew/show/P3959 原来写了个不枚举起点的状压dp. #include<iostream> #include< ...
- 【洛谷4941】War2 状压Dp
简单的状压DP,和NOIP2017 Day2 找宝藏 代码几乎一样.(比那个稍微简单一点) f[i][j] ,i代表点的状态,j是当前选择的点,枚举上一个选到的点k 然后从f[i-(1<< ...
- 【洛谷P3959】[NOIP2017] 宝藏
宝藏 题目链接 首先,打了一个prim,得了45分 #include<iostream> #include<cstring> #include<cstdio> #i ...
- 洛谷P2473奖励关——状压DP
题目:https://www.luogu.org/problemnew/show/P2473 还是对DP套路不熟悉... 像这种前面影响后面,而后面不影响前面的问题就应该考虑倒序递推: 看n只有15那 ...
- 洛谷 P3112 后卫马克 —— 状压DP
题目:https://www.luogu.org/problemnew/show/P3112 状压DP...转移不错. 代码如下: #include<iostream> #include& ...
- 洛谷 P1433 吃奶酪 状压DP
题目描述 分析 比较简单的状压DP 我们设\(f[i][j]\)为当前的状态为\(i\)且当前所在的位置为\(j\)时走过的最小距离 因为老鼠的坐标为\((0,0)\),所以我们要预处理出\(f[1& ...
- 2018.11.02 洛谷P2831 愤怒的小鸟(状压dp)
传送门 状压一眼题. 直接f[i]f[i]f[i]表示未选择状态为iii时的最小次数. 然后考虑现在怎么转移. 显然可以直接枚举消掉某一个点或者某两个点,复杂度O(n22n)O(n^22^n)O(n2 ...
随机推荐
- ASP.NET Core 防止跨站请求伪造(XSRF/CSRF)攻击 (转载)
什么是反伪造攻击? 跨站点请求伪造(也称为XSRF或CSRF,发音为see-surf)是对Web托管应用程序的攻击,因为恶意网站可能会影响客户端浏览器和浏览器信任网站之间的交互.这种攻击是完全有可能的 ...
- BZOJ3817 清华集训2014 Sum 类欧几里得
传送门 令\(\sqrt r = x\) 考虑将\(-1^{\lfloor d \sqrt r \rfloor}\)魔改一下 它等于\(1-2 \times (\lfloor dx \rfloor \ ...
- CF1038E Maximum Matching 搜索/区间DP
题目传送门:http://codeforces.com/problemset/problem/1038/E 题意:给出$N$个方块,每个方块有左右两种颜色$a,b$(可以翻转使左右两种颜色交换)和一个 ...
- [Spark][Python]spark 从 avro 文件获取 Dataframe 的例子
[Spark][Python]spark 从 avro 文件获取 Dataframe 的例子 从如下地址获取文件: https://github.com/databricks/spark-avro/r ...
- DefWindowProc是一个会产生消息的函数
先看一道题目: 当用户点击右上角关闭按钮的时候,请给下列Windows做出的响应排个序:A:发送 WM_QUIT 消息 B:发送 WM_CLOSE 消息 C:发送 WM_DESTROY ...
- 2018年计划小里程碑(6月)PMI-ACP 敏捷
年初定的计划之一,考证... 7A,意料之外,也是意料之中.历时两个月多,2018.3.31号决定报名,顶着压报了ACP+ACP实战+PMP,考虑了下敏捷是未来项目管理的趋势,大部分公司正在向敏捷转型 ...
- Safecracker-HDU1015
题意 给你大写字母的字符串,A=1,...Z=26,以及target 问你是否有v - w^2 + x^3 - y^4 + z^5 = target 有输出字典序大的那个字符串 分析 dfs code ...
- 计算机终端安装成功的包 pycharm不能更新
最近在学习python的时候遇到一个麻烦事 要用到pymssql包 在CMD下已经安装成功 但是在pycharm中运行的时候出现 没有这个包 以往的方法是在设置界面 通过+号安装需要的包 但 ...
- answer my questions from the book<构建之法>.
1)何为文档:文档时在一个项目进行的一生中所有记忆的集合.有需求分析.功能设计.在实现功能过程中也可以有一系列文档记录.测试文档等等. 2)结对工作等找队友会花费大量时间致耽误项目否:正如老师所讲,从 ...
- BugPhobia进阶篇章:系统架构技术规格
0x01 :开发级需求分析 在开发过程中,团队本身在开发的起始阶段确定了基本的开发级需求分析: 在开发过程中,除了需要满足用户级需求以为,我们还需要针对开发团队的特点,满足一些开发级的需求和约束.作为 ...