[atARC078F]Mole and Abandoned Mine
注意到最终图的样子可以看作一条从1到$n$的路径,以及删去这条路径上的边后,路径上的每一个点所对应的一个连通块
考虑dp,令$f_{S,i}$表示当前1到$n$路径上的最后一个点以及之前点(包括$i$)所对应连通块的并,转移考虑枚举下一个点以及其对应的连通块,即$f_{S\cup T,j}=\min(f_{S,i}+sum(S,T)-len(i,j))$
(其中$len(i,j)$表示$(i,j)$这条边的长度,$sum(S,T)=\sum_{x\in S,y\in T,(x,y)\in E}len(x,y)$)
初始状态为$f_{S,1}=0$(其中$1\in S$且$S$的导出子图连通),$f_{other}=\infty$
转移条件为$(i,j)\in E$、$j\in T$、$S\cap T=\empty$且$T$的导出子图连通,因此转移复杂度为$o(n^{2}3^{n})$(关于$T$导出子图连通的这个条件预处理即可)
进一步优化,关于$j$和$T$的枚举可以分开,即先求出$g_{j}=\min(f_{S,i}-len(i,j))$,再枚举包含$j$的$T$即可(这样做的实际意义是先将$S$中所有到$j$的边选择最小的),时间复杂度降为$o(n3^{n})$

1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 15
4 struct ji{
5 int nex,to,len;
6 }edge[N*N];
7 int E,n,m,x,y,z,head[N],vis[N],g[N],con[1<<N],sum[1<<N],f[1<<N][N];
8 void add(int x,int y,int z){
9 edge[E].nex=head[x];
10 edge[E].to=y;
11 edge[E].len=z;
12 head[x]=E++;
13 }
14 void dfs(int k,int s){
15 if (((s&(1<<k))==0)||(vis[k]))return;
16 vis[k]=1;
17 for(int i=head[k];i!=-1;i=edge[i].nex)dfs(edge[i].to,s);
18 }
19 int main(){
20 scanf("%d%d",&n,&m);
21 memset(head,-1,sizeof(head));
22 for(int i=1;i<=m;i++){
23 scanf("%d%d%d",&x,&y,&z);
24 add(x-1,y-1,z);
25 add(y-1,x-1,z);
26 }
27 memset(f,0x3f,sizeof(f));
28 for(int i=0;i<(1<<n);i++){
29 memset(vis,0,sizeof(vis));
30 for(int j=0;j<n;j++)
31 if (i&(1<<j)){
32 dfs(j,i);
33 break;
34 }
35 bool flag=0;
36 for(int j=0;j<n;j++)
37 if ((i&(1<<j))&&(!vis[j])){
38 flag=1;
39 break;
40 }
41 if (!flag){
42 con[i]=1;
43 if (i&1)f[i][0]=0;
44 }
45 }
46 for(int i=1;i<(1<<n);i+=2){
47 if (!con[i])continue;
48 for(int x=0;x<n;x++){
49 g[x]=0x3f3f3f3f;
50 sum[(1<<x)]=0;
51 }
52 for(int x=0;x<n;x++)
53 if ((i&(1<<x))){
54 for(int j=head[x];j!=-1;j=edge[j].nex){
55 y=edge[j].to;
56 if ((i&(1<<y))==0){
57 g[y]=min(g[y],f[i][x]-edge[j].len);
58 sum[(1<<y)]+=edge[j].len;
59 }
60 }
61 }
62 int ii=(1<<n)-1-i;
63 for(int j=(ii&(ii-1));j>=0;j=((j-1)&ii)){
64 int jj=(ii^j),k=(jj&(jj-1));
65 sum[jj]=sum[jj^k]+sum[k];
66 if (jj==ii)break;
67 }
68 for(int x=0;x<n;x++)
69 for(int j=ii;j;j=((j-1)&ii))
70 if ((j&(1<<x))&&(con[j]))f[i|j][x]=min(f[i|j][x],g[x]+sum[j]);
71 }
72 printf("%d",f[(1<<n)-1][n-1]);
73 }
[atARC078F]Mole and Abandoned Mine的更多相关文章
- Mole and Abandoned Mine
Mole and Abandoned Mine n点m条边的无向图,删除第i条边花费c[i],问1到n只有一条路径时所需要的最小花费? \(2\le n\le 15\) . 我又A掉了一道zzs的题啦 ...
- AT2657 Mole and Abandoned Mine
传送门 好神的状压dp啊 首先考虑一个性质,删掉之后的图一定是个联通图 并且每个点最多只与保留下来的那条路径上的一个点有边相连 然后设状态:\(f[s][t]\)代表当前联通块的点的状态为\(s\)和 ...
- 题解-AtCoder ARC-078F Mole and Abandoned Mine
problem ATC-arc078F 题意概要:给定一个 \(n\) 点 \(m\) 边简单无向图(无自环无重边),边有费用,现切去若干条边,使得从 \(1\) 到 \(n\) 有且仅有一条简单路径 ...
- AtCoder arc078_d Mole and Abandoned Mine
洛谷题目页面传送门 & AtCoder题目页面传送门 给定一个无向连通带权图\(G=(V,E),|V|=n,|E|=m\)(节点从\(0\)开始编号),要删掉一些边使得节点\(0\)到\(n- ...
- AT2657 [ARC078D] Mole and Abandoned Mine
简要题解如下: 记 \(1\) 到 \(n\) 的路径为关键路径. 注意到关键路径只有一条是解题的关键,可以思考这张图长什么样子. 不难发现关键路径上所有边均为桥,因此大致上是关键路径上每个点下面挂了 ...
- 【做题】arc078_f-Mole and Abandoned Mine——状压dp
题意:给出一个\(n\)个结点的联通无向图,每条边都有边权.令删去一条边的费用为这条边的边权.求最小的费用以删去某些边使得结点\(1\)至结点\(n\)有且只有一条路径. \(n \leq 15\) ...
- AtCoder Regular Contest 078
我好菜啊,ARC注定出不了F系列.要是出了说不定就橙了. C - Splitting Pile 题意:把序列分成左右两部分,使得两边和之差最小. #include<cstdio> #inc ...
- 【AtCoder】ARC078
C - Splitting Pile 枚举从哪里开始分的即可 #include <bits/stdc++.h> #define fi first #define se second #de ...
- AtCoder刷题记录
构造题都是神仙题 /kk ARC066C Addition and Subtraction Hard 首先要发现两个性质: 加号右边不会有括号:显然,有括号也可以被删去,答案不变. \(op_i\)和 ...
随机推荐
- nginx配置禁止爬虫配置
1.在配置文件里添加禁止爬虫配置 server { ------ #添加如下内容即可防止爬虫 if ($http_user_agent ~* "qihoobot|Baiduspider|Go ...
- 『基于ArcGIS的Python编程秘籍(第2版)』书本源码
ArcPy学习 第1章 面向ArcGIS的Python编程语言的基础 略 第2章 管理地图文档和图层 引用当前的地图文档 引用磁盘上的地图文档 获取地图文档的图层列表 限制图层列表 缩放至所选要素 改 ...
- 洛谷2543AHOI2005]航线规划 (树剖+线段树+割边思路)
这个题的思路还是比较巧妙的. 首先,我们发现操作只有删除和询问两种,而删除并不好维护连通性和割边之类的信息. 所以我们不妨像WC2006水管局长那样,将询问离线,然后把操作转化成加边和询问. 然后,我 ...
- Lynis 漏洞扫描工具部署及效果展示
Lynis 漏洞扫描工具部署及效果展示 介绍 Lynis是一个安全审计工具,它可以在Linux,macOS和其他基于Unix的系统上运行.Lynis的主要重点是执行系统的运行状况检查,它还有助于检测漏 ...
- 初学Python-day8 案例2
中奖率 1 import random 2 num = 123456 3 i = 1 4 while True: 5 win = random.randrange(100000, 999999) 6 ...
- 《手把手教你》系列技巧篇(三十四)-java+ selenium自动化测试-单选和多选按钮操作-中篇(详解教程)
1.简介 今天这一篇宏哥主要是讲解一下,如何使用list容器来遍历单选按钮.大致两部分内容:一部分是宏哥在本地弄的一个小demo,另一部分,宏哥是利用JQueryUI网站里的单选按钮进行实战. 2.d ...
- [敏捷软工团队博客]Beta阶段事后分析
设想和目标 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 我们的软件要解决的问题是:现在的软工课程的作业分布在博客园.GitHub上,没有一个集成多种功能的一体化 ...
- 【学习笔记】Vizing 定理
图染色问题的经典结论 定义 称一个边染色方案合法当且仅当每个顶点连出的所有边的颜色都互不相同,如果此时出现了 \(k\) 个颜色那么称该方案是图的一组 \(k\) 染色 一张无向图的边着色数为最小的 ...
- Java 将Excel转为et和ett格式
以.et结尾的文件格式是属于金山办公软件WPS Office中的电子表格文件,.ett是一种模板文件格式.除了通过WPS软件可以创建该格式的电子表格外,也可以通过格式转换的方法来获得,如将Micros ...
- 编译内核错误:Can't use 'defined(@array)' (Maybe you should just omit the defined()?) at kernel/timeconst.pl line 373
最近在编译一个新的rk sdk的时候,编译内核报错 CHK include/linux/version.h CHK include/generated/utsrelease.h make[1]: 'i ...