cf1000E】的更多相关文章

题意:无向联通图,求一条最长的路径,路径长度定义为u到v必须经过的边的个数 如果把强联通分量都缩成一个点以后,每个点内部的边都是可替代的:而又因为这是个无向图,缩完点以后就是棵树,跑两遍dfs求直径即可 #include<bits/stdc++.h> #define pa pair<int,int> #define CLR(a,x) memset(a,x,sizeof(a)) using namespace std; typedef long long ll; ; inline l…
题目大意:给一张无向图,要求找一对$s$和$t$,使得其路径上的割边是最多的,输出其数量. 题解:把边双缩点以后求树的直径. 卡点:无 C++ Code: #include <cstdio> #include <cstring> #define maxn 300010 #define maxm 300010 #define ONLINE_JUDGE #define read() R::READ() #include <cctype> namespace R { int…
这道题绝不是紫题... 题目的意思其实是让你求一个无向无重边图的直径. 对于求直径的问题我们以前研究过树的直径,可以两遍dfs或者两边bfs解决. 对于图显然不能这样解决,因为图上两点之间的简单路径不唯一. 那怎么解决这个问题呢? 能不能把环都搞掉呢? 于是乎,我们想到了强连通分量. 因此先用tarjan缩一下点,重新建图跑一个直径就可以解决这个问题了. AC代码如下: 3053ms 23816kb #include<bits/stdc++.h> using namespace std; na…
题意理解了就很好做 题意:给一张无向图,任意取两个点s,t,s->t的路径上必经边数量为k 求这样的s,t,使得k最大 #include<bits/stdc++.h> #define maxn 300005 using namespace std; ],e_c[maxn<<]; int head[maxn],tot,head_c[maxn],tot_c,n,m; void init(){ memset(head,-,sizeof head); memset(head_c,-,…
先缩点构造出一颗树,然后求树的直径就好 const int maxn=3e5+5; const int maxm=6e5+5; const int inf=1e9; int head[maxn],ver[maxm],nex[maxm],tot; void inline AddEdge(int x,int y){ ver[++tot]=y,nex[tot]=head[x],head[x]=tot; } int n,m; bool bridge[maxm]; int dfn[maxn],low[ma…