【BZOJ3590】[Snoi2013]Quare 状压DP
这道题。。。神题。
首先看到数据范围,一眼状压 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的更多相关文章
- BZOJ3590 SNOI2013Quare(状压dp)
可能作为最优解的边双都可以这样生成:初始时边双内只有一个点,每次选取边双内部两点(可以相同)和一个当前不在边双内的点集,以该两点为起止点找一条链(当然如果两点相同就是个环)将点集串起来,加入边双.状压 ...
- BZOJ 1087: [SCOI2005]互不侵犯King [状压DP]
1087: [SCOI2005]互不侵犯King Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 3336 Solved: 1936[Submit][ ...
- nefu1109 游戏争霸赛(状压dp)
题目链接:http://acm.nefu.edu.cn/JudgeOnline/problemShow.php?problem_id=1109 //我们校赛的一个题,状压dp,还在的人用1表示,被淘汰 ...
- poj3311 TSP经典状压dp(Traveling Saleman Problem)
题目链接:http://poj.org/problem?id=3311 题意:一个人到一些地方送披萨,要求找到一条路径能够遍历每一个城市后返回出发点,并且路径距离最短.最后输出最短距离即可.注意:每一 ...
- [NOIP2016]愤怒的小鸟 D2 T3 状压DP
[NOIP2016]愤怒的小鸟 D2 T3 Description Kiana最近沉迷于一款神奇的游戏无法自拔. 简单来说,这款游戏是在一个平面上进行的. 有一架弹弓位于(0,0)处,每次Kiana可 ...
- 【BZOJ2073】[POI2004]PRZ 状压DP
[BZOJ2073][POI2004]PRZ Description 一只队伍在爬山时碰到了雪崩,他们在逃跑时遇到了一座桥,他们要尽快的过桥. 桥已经很旧了, 所以它不能承受太重的东西. 任何时候队伍 ...
- bzoj3380: [Usaco2004 Open]Cave Cows 1 洞穴里的牛之一(spfa+状压DP)
数据最多14个有宝藏的地方,所以可以想到用状压dp 可以先预处理出每个i到j的路径中最小权值的最大值dis[i][j] 本来想用Floyd写,无奈太弱调不出来..后来改用spfa 然后进行dp,这基本 ...
- HDU 1074 Doing Homework (状压dp)
题意:给你N(<=15)个作业,每个作业有最晚提交时间与需要做的时间,每次只能做一个作业,每个作业超出最晚提交时间一天扣一分 求出扣的最小分数,并输出做作业的顺序.如果有多个最小分数一样的话,则 ...
- 【BZOJ1688】[Usaco2005 Open]Disease Manangement 疾病管理 状压DP
[BZOJ1688][Usaco2005 Open]Disease Manangement 疾病管理 Description Alas! A set of D (1 <= D <= 15) ...
随机推荐
- C#设计模式(8)——外观模式
1.外观模式介绍 外观模式也被叫做门面模式,这种模式的作用是:隐藏系统的复杂性,并向客户端提供了一个可以访问系统的统一接口,这个统一的接口组合了子系统的多个接口.使用统一的接口使得子系统更容易被访问或 ...
- [JVM-3]Java垃圾回收(GC)机制和垃圾收集器选择
哪些内存需要回收? 1.引用计数法 这个算法的实现是,给对象中添加一个引用计数器,每当一个地方引用这个对象时,计数器值+1:当引用失效时,计数器值-1.任何时刻计数值为0的对象就是不可能再被使用的.这 ...
- IDEA DEBUG无法启动
如题:idea DEBUG无法启动 解决方法: 1.查找出占用进程id 2.杀死进程 cmd 输入 命令: 1.netstat -ano|findstr 4405 2.taskkill -f -pid ...
- jQuery使用(二):DOM样式操作和属性操作
DOM取值与赋值 .html() .text() .size() 1.html()方法类似原生DOM的属性innerHTML,不传入参数的时候默认为取指定元素内的HTML内容,包含前后空白文本结构,以 ...
- 正则表达式基于JavaScript的入门详解
关于正则表达式,和很多前辈聊起这个知识点时,他们的反馈都比聊其他技术谦逊,而和很多刚入门的程序员讨论时甚至会有觉得你看不起他. 的确,正则表达式从通常的应用来看,的确不难,比如电话,邮箱等验证.语法, ...
- vue常用指令
1.v-if系列 v-if="数据|判断" 只要条件成立,就显示if中的元素 v-else (注意:必须跟在v-if或者v-if-else的后面,不然失效) 如果if条件不成立显示 ...
- C#控件绘图恢复最小化后不自动重绘问题
最近在学习C#中的绘图,使用控件绘图时发现一个现象:即使将绘图代码写在了Paint方法中,将窗口最小化再恢复后依然不会重绘,而只有将鼠标移到控件上或者有其他改变窗口的行为时才会重绘. 一开始以为是自己 ...
- Python安全 - 从SSRF到命令执行惨案
前两天遇到的一个问题,起源是在某个数据包里看到url=这个关键字,当时第一想到会不会有SSRF漏洞. 以前乌云上有很多从SSRF打到内网并执行命令的案例,比如有通过SSRF+S2-016漏洞漫游内网的 ...
- TF, IDF和TF-IDF
在相似文本的推荐中,可以用TF-IDF来衡量文章之间的相似性. 一.TF(Term Frequency) TF的含义很明显,就是词出现的频率. 公式: 在算文本相似性的时候,可以采用这个思路,如果两篇 ...
- javascript数据类型和常用内置对象(重要!)
数据类型:w3c undefind null string number boolean Array object 常用内置javascript对象: Array对象:Date对象:正则 ...