这一题,我当年只会$60$分做法。。。。。

我们考虑对原图跑一波边双,然后缩成一个森林。

对于森林中的每一棵树,我们钦定一个根。

令$siz[x]$表示以$x$为根的子树中,在原图中点的个数。

令当前的答案为$ans$

对于一条边$(u,v)$,如果这两个点在缩点后的同个点内,那么什么都不用管,直接输出$ans$即可。

否则我们先令$u=d[u]$,$v=d[v]$,其中$d[i]$表示原图中第$i$号点在缩点后的森林中的编号。

显然这两个点在同一棵树内,不妨设$dep[u]>dep[v]$,令$rt$表示$u$所在的树的根。

显然断掉这条边,增加的非联通点对个数为$siz[u]\times (siz[rt]-siz[u])$。

加上$ans$输出即可。

注意对1000取模!!!

 #include<bits/stdc++.h>
#define L long long
#define M 100005
using namespace std; struct edge{int u,next;}e[M*]={}; int head[M]={},head1[M]={},use=;
void add(int x,int y){e[use].u=y;e[use].next=head[x];head[x]=use++;}
void add1(int x,int y){use++;e[use].u=y;e[use].next=head1[x];head1[x]=use;}
int dfn[M]={},low[M]={},b[M]={},d[M]={},siz[M]={},cnt=,t=; stack<int> s;
int n,m,q;
void dfs(int x,int fa){
dfn[x]=low[x]=++t; s.push(x); b[x]=;
for(int i=head[x];~i;i=e[i].next)
if(i!=fa){
if(!dfn[e[i].u]) dfs(e[i].u,i^),low[x]=min(low[x],low[e[i].u]);
else if(b[e[i].u]) low[x]=min(low[x],dfn[e[i].u]);
}
if(dfn[x]==low[x]){
cnt++; int u;
do{
u=s.top();s.pop();
b[x]=; d[u]=cnt; siz[cnt]++;
}while(u!=x);
}
}
int du[M]={},dep[M]={},ff[M]={};
void dfs1(int x,int fa){
dep[x]=dep[fa]+; ff[x]=ff[fa];
for(int i=head1[x];i;i=e[i].next)
if(e[i].u!=fa)
dfs1(e[i].u,x),siz[x]+=siz[e[i].u];
} int U[M*]={},V[M*]={};
int main(){
memset(head,-,sizeof(head));
scanf("%d%d%d",&n,&m,&q);
for(int i=;i<=m;i++){
int x,y; scanf("%d%d",&x,&y);
x++; y++;
add(x,y); add(y,x);
U[i]=x; V[i]=y;
}
for(int i=;i<=n;i++) if(!dfn[i])
dfs(i,-);
for(int x=;x<=n;x++)
for(int i=head[x];~i;i=e[i].next)
if(d[x]!=d[e[i].u]){
add1(d[x],d[e[i].u]); du[d[x]]++;
}
L ans=1LL*n*n;
for(int i=;i<=cnt;i++)
if(du[i]==||(du[i]==&&dep[i]==)){
ff[]=i; dfs1(i,);
ans-=1LL*siz[i]*siz[i];
}
ans/=;
while(q--){
int id,x,y; scanf("%d",&id); id++;
x=U[id]; y=V[id];
x=d[x]; y=d[y];
if(x==y||ff[x]!=ff[y]){printf("%lld\n",ans%); continue;}
if(dep[x]<dep[y]) swap(x,y);
L minus=1LL*siz[x]*(siz[ff[y]]-siz[x]);
printf("%lld\n",(ans+minus)%);
}
}

【GDOI2015】 水题 tarjan缩点的更多相关文章

  1. bzoj 1179 [APIO 2009]Atm(APIO水题) - Tarjan - spfa

    Input 第一行包含两个整数N.M.N表示路口的个数,M表示道路条数.接下来M行,每行两个整数,这两个整数都在1到N之间,第i+1行的两个整数表示第i条道路的起点和终点的路口编号.接下来N行,每行一 ...

  2. 通讯(tarjan缩点)(20190716NOIP模拟测试4)

    B. 通讯   题目类型:传统 评测方式:文本比较  内存限制:256 MiB 时间限制:1000 ms 标准输入输出 题目描述 “这一切都是命运石之门的选择.” 试图研制时间机器的机关SERN截获了 ...

  3. 20190716NOIP模拟赛T2 通讯(tarjan缩点+贪心)

    题目描述 “这一切都是命运石之门的选择.” 试图研制时间机器的机关SERN截获了中二科学家伦太郎发往过去的一条短 信,并由此得知了伦太郎制作出了电话微波炉(仮). 为了掌握时间机器的技术,SERN总部 ...

  4. P1262 间谍网络 (tarjan缩点 水过去)

    题目描述 由于外国间谍的大量渗入,国家安全正处于高度的危机之中.如果A间谍手中掌握着关于B间谍的犯罪证据,则称A可以揭发B.有些间谍收受贿赂,只要给他们一定数量的美元,他们就愿意交出手中掌握的全部情报 ...

  5. Tarjan水题系列(3):HNOI2006 潘多拉的魔盒

    题目: 链接 大意: 盒子与盒子之间的关系构成一个有向图 求图上包含节点数最多的路径的节点数 思路: 有向图上求包含节点数最多的路径的节点数 可直接使用tarjan缩点后拓扑dp求得 在此不赘述 此题 ...

  6. 【Tarjan缩点】PO3352 Road Construction

    Road Construction Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 12532   Accepted: 630 ...

  7. Wannafly14挑战赛 C(tarjan缩点)题解

    题目:牛客题目链接 思路:这道题有点像这道题 先缩点,缩完之后判断一下整个强连通分量入度是不是0,如果是的话向ans压入该强连通分量最小的那个值.最后排序一下ans输出就行了. 思路一下就想到了,就是 ...

  8. POJ 1236 Network of Schools Tarjan缩点

    Network of Schools Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 22729   Accepted: 89 ...

  9. 【模拟7.16】通讯(tarjan缩点加拓扑排序)

    这题确实水,纯板子,考试意外出错,只拿了暴力分QAQ tarjan缩点加上拓扑排序,注意这里求最短路径时不能用最小生成树 因为是单向边,不然就可能不是一个联通图了.... 1 #include< ...

随机推荐

  1. Mybatis Blob和String互转,实现文件上传等。

    这样的代码网上有很多,但是本人亲测有bug, 下面是我写的代码.望参考 @MappedJdbcTypes(JdbcType.BLOB) public class BlobAndStringTypeHa ...

  2. 构造函数constructor 与析构函数destructor(一)

    构造函数定义:构造函数c++中在创建对象时自动调用,用来初始化对象的特殊函数. (1)构造函数的名字必须与类的名字相同,不能有返回值,哪怕是void 也不行. (2)通常情况下构造函数应声明为公有函数 ...

  3. 2018.09.15 poj1041John's trip(欧拉路输出方案)

    传送门 一个欧拉路输出方案的板子题. 竟然难在读入233. 代码: #include<iostream> #include<cstdio> #include<cstrin ...

  4. 2018.07.22哨戒炮 II(树形dp)

    哨戒炮 II 描述 你的防线成功升级,从原来的一根线变成了一棵树.这棵树有 N 个炮台,炮台与炮台之间 有 N-1 条隧道.你要选择一些炮台安装哨戒炮.在第 i 个炮台上安装哨戒炮得到的防御力为 vi ...

  5. gridcontrol 图片列异步加载

    在gridview中指定一列,将ColumnEdit设置成pictureEdit 在使用showDialog这里窗体后,需要frm.Dispose()将资源释放 1.将该列的UnboundType属性 ...

  6. Android绘图板的开发

    >>继承自View >>使用Canvas绘图 每次View组件上的图形状态数据发生了改变,都应该通知View组件重写调用onDraw(Canvas canvas)方法重绘该组件 ...

  7. day06(Collection,List,ArrayList,LinkedList,iterator迭代器,增强for)

    Collection   接口    方法实现 boolean  add(Object o);//添加 boolean  remove(Object o);//移除 修改方法   让实现类自己去实现修 ...

  8. (最小生成树)Jungle Roads -- HDU --1301

    链接: http://acm.hdu.edu.cn/showproblem.php?pid=1301 http://acm.hust.edu.cn/vjudge/contest/view.action ...

  9. HDU6205 Coprime Sequence 2017-05-07 18:56 36人阅读 评论(0) 收藏

    Coprime Sequence                                                        Time Limit: 2000/1000 MS (Ja ...

  10. [mobile]移动端页面没有重新请求时,刷新页面代码

    <input type="hidden" value="yes" id="id_if_reload" /> <script ...