洛谷题目传送门

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. visual studio Web发布至 IIS WebDeploy出错(未能创建SSL/TLS安全通道)Could not create SSL/TLS secure channel

    问题发生的原因是VS 15.9尝试使用系统默认值进行TLS握手,但是要在VS内的某处设置为TLS1.2. 此问题的解决方法是在部署项目的IIS服务器上启用TLS 1.2.例如,请按照此文章中的说明操作

  2. odoo在底部显示指定字段合计和汇总时显示合计

    1.odoo的tree视图底部显示合计 tree 视图,底部显示指定字段合计数 ,视图中字段定义上在sum,取自sale.view_order_tree 销售订单 tree 视图 <field ...

  3. oracle-union all与order by联合使用

    今天写sql的时候,第一次使用union all+order by .是个比较简单的问题,但由于对数据库的不深入理解导致犯了愚蠢的错.浪费了很多时间 如题: 两个子查询union all 需要用ord ...

  4. [Oacle][Partition]Partition操作与 Index, Global Index 的关系

    [Oacle][Partition]Partition操作与 Index, Global Index 的关系: ■ Regarding the local index and the global i ...

  5. 2.RapidIO串行物理层的包与控制符号

    转自https://www.cnblogs.com/liujinggang/p/9932150.html 一.RapidIO串行物理层背景介绍 上篇博文提到RapidIO的物理层支持串行物理层与并行物 ...

  6. python第二周。2019.4.13

    1, 我绘制大蟒蛇就是..保存也对着呢,你要是打开文件的话,先闪个黑屏,再闪个白屏..自动退出,然后啥都没了. 我觉得是我代码编错了...再来一遍! 这次到可以,但是这个大蟒蛇好像没有回头... 刚才 ...

  7. LVM常规操作记录梳理(扩容/缩容/快照等)

    基本介绍Linux用户安装Linux 操作系统时遇到的一个最常见的难以决定的问题就是如何正确地给评估各分区大小,以分配合适的硬盘空间.随着 Linux的逻辑盘卷管理功能的出现,这些问题都迎刃而解, l ...

  8. Zookeeper 源码学习(一)环境搭建

    前言 最近准备学习 Zookeeper,想从 Zookeeper 开始逐步深入了解各类中间件,学习分布式计算. 下载源码 执行指令,下载代码: git clone https://github.com ...

  9. 【个人总结】软件工程M1/M2总结

    个人博客连接: http://www.cnblogs.com/lwq12061168/p/4094252.html http://www.cnblogs.com/lwq12061168/p/40284 ...

  10. M2事后总结

    照片     设想和目标 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? "北航"Clubs旨在于解决北航校内社团管理与学生参与社团活动的困难的 ...