这道题。。。神题。

首先看到数据范围,一眼状压 dp 。然后? 没了。

理性分析,这里说断掉任意一条边图依然连通,即整个图构成一个边双(而不是点双)。

之前用 fire (机房里的随机算法总称)之所以过不掉大概是我想错性质了(边双的条件直接变成 任意点的度大于2),

再打一遍 fire 不知道能不能过(可能关于判边双会十分麻烦,且复杂度较高)。

在这里我们考虑一个边双加上一条链(链的两端都在边双的集合里面),然后这个图依旧是边双。

那么在这里,一个点既是边双又是链,只不过要特判点 这一特殊情况。

然后我们可以处理出每一条链的最短长度,再进行边双最优解转移。

 //by Judge
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
const int inf=1e9+;
const int M=(<<)+;
#ifndef Judge
#define getchar() (p1==p2&&(p2=(p1=buf)+fread(buf,1,1<<21,stdin),p1==p2)?EOF:*p1++)
#endif
inline void cmin(int& a,int b){if(a>b)a=b;}
char buf[<<],*p1=buf,*p2=buf;
inline int read(){ int x=,f=; char c=getchar();
for(;!isdigit(c);c=getchar()) if(c=='-') f=-;
for(;isdigit(c);c=getchar()) x=x*+c-''; return x*f;
} int n,m,pat,msk,head[],log[M],h1[][M],h2[][M],g[][][M],f[M];
struct edge{ int to,val,next; }e[];
inline void add(int x,int y,int z){
e[++pat]={y,z,head[x]},head[x]=pat;
e[++pat]={x,z,head[y]},head[y]=pat;
}
#define lowbit(x) (x&-x)
int main(){ int T=read();
while(T--){ n=read(),m=read(),
msk=(<<n)-,pat=;
memset(head,,sizeof(head));
for(int i=;i<n;++i) log[<<i]=i;
for(int i=,a,b,c;i<m;++i)
a=read()-,b=read()-,
c=read(),add(a,b,c);
memset(h1,0x0f,sizeof(h1)),
memset(h2,0x0f,sizeof(h2)),
memset(g,0x0f,sizeof(g));
memset(f,0x0f,sizeof(f));
#define v e[i].to
for(int i,S=,a;S<=msk;++S){
for(int ta=msk^S;ta;ta-=lowbit(ta)){
for(a=log[lowbit(ta)],i=head[a];i;i=e[i].next) if((S>>v)&){
if(e[i].val<h1[a][S]) h2[a][S]=h1[a][S],h1[a][S]=e[i].val;
else cmin(h2[a][S],e[i].val);
}
}
}
for(int i=;i<n;++i) g[i][i][<<i]=f[<<i]=;
for(int S=;S<=msk;++S) for(int ta=S,a;ta;ta-=lowbit(ta))
for(int tb=S,b;tb;tb-=lowbit(tb)){
a=log[lowbit(ta)],b=log[lowbit(tb)]; if(a==b) continue;
for(int i=head[b];i;i=e[i].next) if((S>>v)&)
cmin(g[a][b][S],g[a][v][S^(<<b)]+e[i].val);
}
for(int S=,a,b;S<=msk;++S) if(S^lowbit(S)){
for(int T=(S-)&S;T;T=(T-)&S) for(int ta=T;ta;ta-=lowbit(ta))
for(int tb=T;tb;tb-=lowbit(tb)){ a=log[lowbit(ta)],b=log[lowbit(tb)];
if(a==b) cmin(f[S],f[S^T]+g[a][b][T]+h1[a][S^T]+h2[a][S^T]);
else cmin(f[S],f[S^T]+g[a][b][T]+h1[a][S^T]+h1[b][S^T]);
}
}
if(f[msk]>=f[]) puts("impossible");
else printf("%d\n",f[msk]);
} return ;
}

【BZOJ3590】[Snoi2013]Quare 状压DP的更多相关文章

  1. BZOJ3590 SNOI2013Quare(状压dp)

    可能作为最优解的边双都可以这样生成:初始时边双内只有一个点,每次选取边双内部两点(可以相同)和一个当前不在边双内的点集,以该两点为起止点找一条链(当然如果两点相同就是个环)将点集串起来,加入边双.状压 ...

  2. BZOJ 1087: [SCOI2005]互不侵犯King [状压DP]

    1087: [SCOI2005]互不侵犯King Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 3336  Solved: 1936[Submit][ ...

  3. nefu1109 游戏争霸赛(状压dp)

    题目链接:http://acm.nefu.edu.cn/JudgeOnline/problemShow.php?problem_id=1109 //我们校赛的一个题,状压dp,还在的人用1表示,被淘汰 ...

  4. poj3311 TSP经典状压dp(Traveling Saleman Problem)

    题目链接:http://poj.org/problem?id=3311 题意:一个人到一些地方送披萨,要求找到一条路径能够遍历每一个城市后返回出发点,并且路径距离最短.最后输出最短距离即可.注意:每一 ...

  5. [NOIP2016]愤怒的小鸟 D2 T3 状压DP

    [NOIP2016]愤怒的小鸟 D2 T3 Description Kiana最近沉迷于一款神奇的游戏无法自拔. 简单来说,这款游戏是在一个平面上进行的. 有一架弹弓位于(0,0)处,每次Kiana可 ...

  6. 【BZOJ2073】[POI2004]PRZ 状压DP

    [BZOJ2073][POI2004]PRZ Description 一只队伍在爬山时碰到了雪崩,他们在逃跑时遇到了一座桥,他们要尽快的过桥. 桥已经很旧了, 所以它不能承受太重的东西. 任何时候队伍 ...

  7. bzoj3380: [Usaco2004 Open]Cave Cows 1 洞穴里的牛之一(spfa+状压DP)

    数据最多14个有宝藏的地方,所以可以想到用状压dp 可以先预处理出每个i到j的路径中最小权值的最大值dis[i][j] 本来想用Floyd写,无奈太弱调不出来..后来改用spfa 然后进行dp,这基本 ...

  8. HDU 1074 Doing Homework (状压dp)

    题意:给你N(<=15)个作业,每个作业有最晚提交时间与需要做的时间,每次只能做一个作业,每个作业超出最晚提交时间一天扣一分 求出扣的最小分数,并输出做作业的顺序.如果有多个最小分数一样的话,则 ...

  9. 【BZOJ1688】[Usaco2005 Open]Disease Manangement 疾病管理 状压DP

    [BZOJ1688][Usaco2005 Open]Disease Manangement 疾病管理 Description Alas! A set of D (1 <= D <= 15) ...

随机推荐

  1. 查询sql数据库中表占用的空间大小

    最近在给一家客户做系统维护时,需要查看数据库表的大小,相关的sql如下: 先在左上角下拉框中选对要查的数据库再执行以下语句 1. exec sp_spaceused '表名'          --( ...

  2. Ubuntu vim下 实现函数跳转功能

    安装sudo apt-get install exuberant-ctags   在每次使用时,需要初始化tags,只有这样才能使用跳转功能 初始化: 进入项目的顶级目录.输入以下命令.        ...

  3. bzoj千题计划322:bzoj2561: 最小生成树(最小割)

    https://www.lydsy.com/JudgeOnline/problem.php?id=2561 考虑Kruscal算法求最小生成树的流程 如果 u和v之间的长为L的边能出现在最小生成树里, ...

  4. 062、如何使用flannel host-gw backend(2019-04-02 周二)

    参考https://www.cnblogs.com/CloudMan6/p/7457653.html   flannel 支持多种backend,前面学习的是 vxlan backend ,host- ...

  5. Silverlight用户无法注册之MySql.Data.dll不一致

    本篇博文记录本人解决一个"用户无法注册"的问题的过程 1 问题描述: 用户可以删除:但不能注册,也不能修改权限: 图 1用户注册失败 图 2修改用户权限出错 2 解决过程 1)粗暴 ...

  6. weui hd bd ft

    weui样式看到hd ,bd, ft hd 是header的缩写 bd 是body的缩写 ft 是footer的缩写

  7. None.js 第四步 事件驱动程序

    Node.js 有多个内置的事件,我们可以通过引入 events 模块,并通过实例化 EventEmitter 类来绑定和监听事件 // 导入events模块 var events = require ...

  8. NSScanner类的基本用法

    NSScanner是一个类,用于在字符串中扫描指定的字符,尤其是把它们翻译/转换为数字和别的字符串.可以在创建NSScaner时指定它的string属性,然后scanner会按照你的要求从头到尾地扫描 ...

  9. C# WinForm多线程(一)----- Thread类库

    Windows是一个多任务的系统,如果你使用的是windows 2000及其以上版本,你可以通过任务管理器查看当前系统运行的程序和进程.什么是进程呢?当一个程序开始运行时,它就是一个进程,进程所指包括 ...

  10. 梯度下降算法对比(批量下降/随机下降/mini-batch)

    大规模机器学习: 线性回归的梯度下降算法:Batch gradient descent(每次更新使用全部的训练样本) 批量梯度下降算法(Batch gradient descent): 每计算一次梯度 ...