洛谷题目传送门

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

\[g_{l,i}=\sum\limits_{j\in i}g_{l-1,i-j}+l*f_{i-j,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)的更多相关文章

  1. 洛谷P3959 宝藏(状压dp)

    传送门 为什么感觉状压dp都好玄学……FlashHu大佬太强啦…… 设$f_{i,j}$表示当前选的点集为$i$,下一次要加入的点集为$j$时,新加入的点和原有的点之间的最小边权.具体的转移可以枚举$ ...

  2. 洛谷 P3959 宝藏【状压dp】

    一开始状态设计错了-- 设f[i][s]为当前与根节点联通状况为s,最深深度为i 转移的话枚举当前没有和根联通的点集,预处理出把这些点加进联通块的代价(枚举s中的点和当前点的连边乘以i即可),然后用没 ...

  3. 洛谷 3959 宝藏——枚举+状压dp

    题目:https://www.luogu.org/problemnew/show/P3959 原来写了个不枚举起点的状压dp. #include<iostream> #include< ...

  4. 【洛谷4941】War2 状压Dp

    简单的状压DP,和NOIP2017 Day2 找宝藏 代码几乎一样.(比那个稍微简单一点) f[i][j] ,i代表点的状态,j是当前选择的点,枚举上一个选到的点k 然后从f[i-(1<< ...

  5. 【洛谷P3959】[NOIP2017] 宝藏

    宝藏 题目链接 首先,打了一个prim,得了45分 #include<iostream> #include<cstring> #include<cstdio> #i ...

  6. 洛谷P2473奖励关——状压DP

    题目:https://www.luogu.org/problemnew/show/P2473 还是对DP套路不熟悉... 像这种前面影响后面,而后面不影响前面的问题就应该考虑倒序递推: 看n只有15那 ...

  7. 洛谷 P3112 后卫马克 —— 状压DP

    题目:https://www.luogu.org/problemnew/show/P3112 状压DP...转移不错. 代码如下: #include<iostream> #include& ...

  8. 洛谷 P1433 吃奶酪 状压DP

    题目描述 分析 比较简单的状压DP 我们设\(f[i][j]\)为当前的状态为\(i\)且当前所在的位置为\(j\)时走过的最小距离 因为老鼠的坐标为\((0,0)\),所以我们要预处理出\(f[1& ...

  9. 2018.11.02 洛谷P2831 愤怒的小鸟(状压dp)

    传送门 状压一眼题. 直接f[i]f[i]f[i]表示未选择状态为iii时的最小次数. 然后考虑现在怎么转移. 显然可以直接枚举消掉某一个点或者某两个点,复杂度O(n22n)O(n^22^n)O(n2 ...

随机推荐

  1. Luogu3514 POI2011 Lollipop 递推、构造

    题目传送门:https://www.luogu.org/problemnew/show/P3514 题意:给出一个只有$1$和$2$的长度为$N$的数列,$M$次询问是否存在一段连续子区间和为$K$. ...

  2. angularjs为ng-click事件传递参数

    在angularjs开发中,我们需要为ng-click事件传递一个参数. 在js中,可以接到参数: 演示:

  3. C# 如何物理删除有主外键约束的记录?存储过程实现

    十年河东,十年河西,莫欺少年穷 本篇主旨是如何物理删除有主外键约束的记录!那么,我们从主外键走起! 下面新建三张有主外键约束的表,分别为:系/学院表,专业班表,学生表,如下: CREATE TABLE ...

  4. SAAS云平台搭建札记: (二) Linux Ubutu下.Net Core整套运行环境的搭建

    最近做的项目,由于预算有限,公司决定不采购Windows服务器,而采购基于Linux的服务器. 一般的VPS服务器,如果使用Windows系统,那么Windows Server2012\2016安装好 ...

  5. 【APIO2016】烟火表演

    题面 题解 神仙题目啊QwQ 设\(f_i(x)\)表示以第\(i\)个点为根的子树需要\(x\)秒引爆的代价. 我们发现,这个函数是一个下凸的一次分段函数. 考虑这个函数合并到父亲节点时会发生怎样的 ...

  6. 在Windows7上如何找到Cookie

    摘要 出于兴趣爱好,前一阵子做了一个网页,网页中需要用到Cookie,但是,根据书上的说明,并没有找打教材中所说的Cookie的位置,本文就主要介绍在计算机(Win7)中Cookie的存放位置,同样适 ...

  7. JVM规范系列第2章:Java虚拟机结构

    本规范描述的是一种抽象化的虚拟机的行为,而不是任何一种(译者注:包括 Oracle 公司自己的 HotSpot 和 JRockit 虚拟机)被广泛使用的虚拟机实现. 记住:JVM规范是一种高度抽象行为 ...

  8. 从零开始搭建属于你的React/redux/webpack脚手架

    大家好,我是苏南,今天要给大家分享的是<<我的react入门到放弃之路>>,当然,也不是真的放弃啦--哈哈,这篇博客原本是从17年初写的,一直没有在csdn发布,希望今天不会太 ...

  9. 如何设置本机电脑的固定IP地址?

    最近使用Loadrunner需要用到IP欺骗,但是我打开设置IP欺骗却提示我:IP向导不支持启用DHCP的网卡.您的卡启用了DHCP或者配置了无效设置.请与系统管理员联系. 我就方了,于是百度了一下, ...

  10. Centos下堡垒机Jumpserver V3.0环境部署完整记录(2)-配置篇

    前面已经介绍了Jumpserver V3.0的安装,基于这篇安装文档,下面说下Jumpserver安装后的的功能使用: 一.jumpserver的启动 Jumpserver的启动和重启 [root@t ...