Break up

CF700C

首先考虑只能删一条边的做法,我们可以找出所有的桥,然后随便跑一条 S 到 T 路径,如果这条路径上有桥就说明可以,否则不行

发现这个做法其实是 O(M) 的

那么可以先随便找一条 N 到 M 的路径,分别尝试删这条路径上的边再套上面做法就好了。

#include<iostream>
#include<cstring>
#include<algorithm>
#include<cstdio>
#include<vector>
#include<queue>
#include<stack>
using namespace std;
//#define int long long
#define MAXN 3016
#define pb push_back
#define pii pair<int,int>
#define fi first
#define se second
#define mp make_pair
#define inf 0x3f3f3f3f
#define cmx( a , b ) a = max( a , b )
#define cmn( a , b ) a = min( a , b )
int n , m , s , t;
int head[MAXN] , nex[MAXN * 50] , to[MAXN * 50] , wto[MAXN * 50] , ecn = -1;
void ade( int u , int v , int w ) {
nex[++ecn] = head[u] , to[ecn] = v , wto[ecn] = w , head[u] = ecn;
}
int vis[MAXN] , pre[MAXN];
int fuck = 0x7f7f7f7f;
bool findpath( int u ) {
if( u == t ) return true;
vis[u] = 1;
for( int i = head[u] ; ~i ; i = nex[i] ) {
if( i == fuck || i == ( fuck ^ 1 ) ) continue;
int v = to[i];
if( vis[v] ) continue;
pre[v] = i ^ 1;
if( findpath( v ) ) return true;
}
return false;
}
int clo;
int dfn[MAXN] , low[MAXN];
int cut[MAXN * 50] , done[MAXN];
int use[MAXN * 50];
void tarjan( int u ) {
done[u] = 1;
dfn[u] = low[u] = ++ clo;
for( int i = head[u] ; ~i ; i = nex[i] ) {
if( use[i] ) continue;
use[i] = use[i ^ 1] = 1;
if( i == fuck || i == ( fuck ^ 1 ) ) continue;
int v = to[i];
if( !dfn[v] ) {
tarjan( v );
low[u] = min( low[u] , low[v] );
if( low[v] > dfn[u] ) cut[i] = cut[i ^ 1] = true;
} else if( done[v] == 1 )
low[u] = min( low[u] , dfn[v] );
}
done[u] = 2;
}
vector<int> eds;
pii ans;
int main() {
memset( head , -1 , sizeof head );
cin >> n >> m >> s >> t;
for( int i = 1 , u , v , w ; i <= m ; ++ i ) {
scanf("%d%d%d",&u,&v,&w);
ade( u , v , w ) , ade( v , u , w );
}
if( !findpath( s ) ) return puts("0") , puts("0") , 0;
int c = t;
while( c != s )
eds.pb( pre[c] ) , c = to[pre[c]];
int res = 0x7f7f7f7f;
for( int i = 0 ; i < eds.size() ; ++ i ) {
fuck = eds[i];
memset( cut , 0 , sizeof cut );
memset( done , 0 , sizeof done );
memset( use , 0 , sizeof use );
memset( dfn , 0 , sizeof dfn );
memset( low , 0 , sizeof low );
clo = 0;
tarjan( s );
memset( vis , 0 , sizeof vis );
if( ! findpath( s ) ) {
if( res > wto[fuck] )
res = wto[fuck] ,
ans = mp( 0 , fuck >> 1 );
continue;
}
c = t;
while( c != s ) {
if( cut[pre[c]] )
if( res > wto[fuck] + wto[pre[c]] )
res = wto[fuck] + wto[pre[c]] , ans = mp( fuck >> 1 , pre[c] >> 1 );
c = to[pre[c]];
}
}
if( res == 0x7f7f7f7f ) return puts("-1") , 0;
if( ! ans.fi ) {
printf("%d\n",wto[ans.se << 1]);
puts("1");
printf("%d",ans.se + 1);
} else {
printf("%d\n",res);
puts("2");
printf("%d %d" , ans.fi + 1 , ans.se + 1);
}
}

Break up CF700C的更多相关文章

  1. CF700C (枚举+tarjan)

    Problem Break up (CF700C) 题目大意 给一张n个点,m条边的无向图,有边权,和起点S,终点T. (n<=1000 , m<=30000) 要求最多割掉2条边,使得S ...

  2. continue break 区别

    在循环中有两种循环方式 continue , break continue 只是跳出本次循环, 不在继续往下走, 还是开始下一次循环 break  将会跳出整个循环, 此循环将会被终止 count = ...

  3. C# 中Switch case 返回不止用break

    Switch(temp) { case "A": //跳出循环 break; case "B": //返回值 return var; case "C& ...

  4. jquery each函数 break和continue功能

    jquery each函数 break和continue功能幸运的是另一个突破,持续一个jQuery循环方式.你可以打破在函数返回一个jQuery参数虚假循环.一个可以继续执行只是在做不指定返回值或返 ...

  5. [LeetCode] Integer Break 整数拆分

    Given a positive integer n, break it into the sum of at least two positive integers and maximize the ...

  6. [LeetCode] Word Break II 拆分词句之二

    Given a string s and a dictionary of words dict, add spaces in s to construct a sentence where each ...

  7. R for循环之break,next

    next跳出本次循环 break跳出本层循环(当有多个for 循环时,即跳出最近的一个for循环)

  8. 关于break语句如何结束多重循环的嵌套

    在Java中的break语句功能大体上同c语言, 用于循环语句中,表示结束当前循环. 但是有时候在循环嵌套语句中,仅仅靠一 个break语句想实现是不够的. 例: 如果想使sum在501时就直接输出, ...

  9. break与continue的区别

    break       在while.for.do...while.while循环中使用break语句退出当前循环,直接执行后面的代码. continue   的作用是仅仅跳过本次循环,而整个循环体继 ...

随机推荐

  1. 【c++ Prime 学习笔记】目录索引

    第1章 开始 第Ⅰ部分 C++基础 第2章 变量和基本类型 第3章 字符串.向量和数组 第4章 表达式 第5章 语句 第6章 函数 第7章 类 第 Ⅱ 部分 C++标准库 第8章 IO库 第9章 顺序 ...

  2. 【Azure 应用服务】App Service For Linux 如何在 Web 应用实例上住抓取网络日志

    问题描述 在App Service For Windows的环境中,我们可以通过ArmClient 工具发送POST请求在Web应用的实例中抓取网络日志,但是在App Service For Linu ...

  3. Gitlab Burndown Chart

    一.说明 通过调用gitlab api直接获取相应project的所有issues,然后对其进行统计以制作燃尽图 二.方法 1.生成 Personal access token Gitlab > ...

  4. 2021.10.10考试总结[NOIP模拟73]

    T1 小L的疑惑 对于\(P_i\),如果所有比\(P_i\)小的数加起来也达不到\(P_i-1\),那么值域肯定不连续.否则设原来值域最大值为\(mx\),则\(P_i\)会让值域最大值增致\(mx ...

  5. CSP-S2021 退役记

    首先大家一起恭喜博主以5pts之差与省三擦肩而过!(nmd爷去年都省三今年成功打铁了) 果然这个菜鸡一年不如一年了 upd:T3死在多测上了,随便一个40+28的人可以吊打我 Day -2: 模拟赛, ...

  6. python +spatialite + window 解决方案(https://www.jianshu.com/p/5bc7d8b7b429)

    运行环境在windows 10 64bit.先将python安装完成.然后,到 spatilite官网 找到MS(即Microsoft)版本,下载64位的mod_spatialite,将其先解压到目标 ...

  7. 攻防世界 杂项 9.a_good_idea

    题目描述: 汤姆有个好主意 解题思路: 首先按照隐写思路找了一下没找到flag,接着使用winhex打开图片,发现图片里面又包含了一张图片,然后马上改了一下后缀为zip, 解压后发现里面有:hint. ...

  8. DDD领域驱动设计-设计规范-Ⅵ

    不以规矩,不能成方圆.                                                                     -战国·邹·孟轲<孟子·离娄章句上 ...

  9. 基于live555开发嵌入式linux系统的rtsp直播服务

    最近要搞一个直播服务,车机本身是个前后双路的Dvr,前路1080P 25fps,后路720P 50fps,现在要连接手机app预览实时画面,且支持前后摄像头画面切换. 如果要做直播,这个分辨率和帧率是 ...

  10. linux下文件后面带~

    之前发现有时候在命令行ls会看到一些文件后面带有-,而这些文件的名字和我们文件夹中的某些文件是一模一样的文件,在文件夹中没发现就很大胆地删掉了也没是,一直没管,觉得是什么临时复制的文件或者隐藏文件.今 ...