【noip暑假tarjan专题】
%%%奎老师
A:傻逼缩点。。。傻逼编译器卡我next。。。
B:就是这道奎老师没讲清楚的题,明明小朋友们都一A嘛,,,明明细节有很多嘛,,,怎么都这么熟练啊。
C:本质还是B,换了个马甲而已。
D:又是缩点,缩完点之后每个入度为1的强连通分量找一下最小值就好啦。。。
I:这就是在求桥了,ok现在来总结一下,有向图中缩点叫强连通分量,求桥与割点,LCA都是在无向图中。然后我又求错了,我在求桥的时候直接算了权值差。。。。看了网上题解,还是乖乖缩点+树形dp吧。。。。QAQ【这里做了双联通之后,就不用求桥啦】有重边,要注意以下。
#include<cstdio> #include<cmath> #include<cstring> #include<algorithm> #define N 50000 using namespace std; int edgenum,n,edgenew,m,all,flag,tm,bian,ans,id,top; int jie[N],num[N],p[N],head[N],size[N],vet[N],uu[N],vv[N],yt[N],low[N],dfn[N],a[N],headnew[N],vetnew[N],nextnew[N],stack[N]; void add(int u,int v) { edgenum++;vet[edgenum]=v;jie[edgenum]=head[u];head[u]=edgenum; } void tarjan(int u,int fa) { tm++;dfn[u]=low[u]=tm;top++;stack[top]=u; ; ) { int v=vet[e]; ){ flag=;e=jie[e];continue; } )tarjan(v,u); low[u]=min(low[u],low[v]);//printf("low==%d %d\n",u,v); e=jie[e]; } if(dfn[u]==low[u]){ id++;num[id]+=a[u];yt[u]=id; while(stack[top]!=u) { int k=stack[top];yt[k]=id;num[id]+=a[k]; top--; }top--; } } void Add(int u,int v) { edgenew++;vetnew[edgenew]=v;nextnew[edgenew]=headnew[u];headnew[u]=edgenew; //printf("add====%d %d\n",u,v); } void dp(int u,int fa) { int e=headnew[u];size[u]=num[u]; //printf("%d\n",u); ) { int v=vetnew[e];//printf("%d\n",v); if(v!=fa)dp(v,u),size[u]+=size[v]; e=nextnew[e]; } )x=-x; ans=min(ans,x); } int main() { while(scanf("%d%d",&n,&m)!=EOF) { edgenum=;edgenew=;memset(headnew,,sizeof(headnew)); memset(head,,,,,sizeof(size)); all=;tm=;bian=;id=top=; memset(low,,,sizeof(dfn)); ;i<=n;i++)scanf("%d",&a[i]),all+=a[i];int u,v; ;i<=m;i++)scanf("%d%d",&u,&v),u++,v++,uu[i]=u,vv[i]=v,add(u,v),add(v,u); tarjan(,); //for(int i=1;i<=n;i++)printf("id==%d\n",low[i]); ){ printf("impossible\n");continue; } ;i<=m;i++) { u=yt[uu[i]],v=yt[vv[i]]; if(u!=v)Add(u,v),Add(v,u); } ans=; dp(,); printf("%d\n",ans); } ; }
双联通
J: 来自hdu2460.。。。。。网上随手找个std发现都是暴力。。。这个世界太不真诚了。
题意大概是求加上新边后桥的数目。。。。这里需要求LCA。。。和双连通分量。
P:树上的LCA,网上90percent的题解用这种做法都会MLE。。。晕。。。不过最后还是过了,有个蛮坑的点是求自己和自己的lca
顺便发现自己连倍增法求LCA都忘了。有空练。
T:这个是真的,不作死就不会死。听说这道题在罗oj交过哦,听说我当时还是p党哦。然后由于懒得码就。。。嘿嘿嘿
【noip暑假tarjan专题】的更多相关文章
- NOIp 图论算法专题总结 (2)
系列索引: NOIp 图论算法专题总结 (1) NOIp 图论算法专题总结 (2) NOIp 图论算法专题总结 (3) 树链剖分 https://oi-wiki.org/graph/heavy-lig ...
- NOIp 图论算法专题总结 (1):最短路、最小生成树、最近公共祖先
系列索引: NOIp 图论算法专题总结 (1) NOIp 图论算法专题总结 (2) NOIp 图论算法专题总结 (3) 最短路 Floyd 基本思路:枚举所有点与点的中点,如果从中点走最短,更新两点间 ...
- NOIp 图论算法专题总结 (3):网络流 & 二分图 简明讲义
系列索引: NOIp 图论算法专题总结 (1) NOIp 图论算法专题总结 (2) NOIp 图论算法专题总结 (3) 网络流 概念 1 容量网络(capacity network)是一个有向图,图的 ...
- NOIP 考前 Tarjan复习
POJ 1236 给定一个有向图,求: 1) 至少要选几个顶点,才能做到从这些顶点出发,可以到达全部顶点 2) 至少要加多少条边,才能使得从任何一个顶点出发,都能到达全部顶点 第一个就是缩点之后有多少 ...
- Tarjan专题
前排Orz tarjan tarjan算法在图的连通性方面有非常多的应用,dfn和low数组真是奥妙重重(并没有很搞懂反正背就完事了) 有向图强连通分量 #include<iostream> ...
- Poj 3233 矩阵快速幂,暑假训练专题中的某一道题目,矩阵快速幂的模板
题目链接 请猛戳~ Description Given a n × n matrix A and a positive integer k, find the sum S = A + A2 + A3 ...
- 校际联合Contest
每次开一个坑都像是重新被碾压的预感 最近的新闻,以前很喜欢乔任梁的<复活>...然后他就死了...感觉我再多愁善感一点的话...就要悲伤逆流成河了吧... Contest 09/24(乐滋 ...
- NOIP赛前集训备忘录(含每日总结)(日更?。。。)
NOIP赛前集训备忘录(含每日考试总结) 标签: 有用的东西~(≧▽≦)/~啦啦啦 阅读体验:https://zybuluo.com/Junlier/note/1279194 考试每日总结(这个东西是 ...
- Collections 索引
About Me NOIp 数据结构专题总结 NOIp 图论算法专题总结 NOIp 基础数论知识点总结 NOIp 数学知识点总结 搜索算法总结 (不包含朴素 DFS, BFS) 位运算 字符串算法总结 ...
随机推荐
- UDP-C#代码
新建两个控制台应用程序,一个是服务端,一个是客户端. 1.服务端代码 using System; using System.Collections.Generic; using System.Linq ...
- iOS添加另一个控制器的时候要注意啊
ios的父控制器控制器和子控制器之间的注意点: " >> #warning 需要把新创建出来的控制器添加成子控制器 . 不然子控制器里面的子控件无法响应点击事件 " 一 ...
- August 13th 2016 Week 33rd Saturday
What makes life dreary is the want of motive. 没有目标与动力,生活便会郁闷无光. Without dreams and hope, there will ...
- cuda编程基础
转自: http://blog.csdn.net/augusdi/article/details/12529247 CUDA编程模型 CUDA编程模型将CPU作为主机,GPU作为协处理器(co-pro ...
- jvm分析
是什么 jps 查看所有的jvm进程,包括进程ID,进程启动的路径等等. jstack 观察jvm中当前所有线程的运行情况和线程当前状态. 系统崩溃了?如果java程序崩溃生成core文件,j ...
- 模拟赛1101d1
完美的序列(sequence)Time Limit:1000ms Memory Limit:64MB题目描述LYK 认为一个完美的序列要满足这样的条件:对于任意两个位置上的数都不相同.然而并不是所有的 ...
- poj1988(并查集)
题目链接:http://poj.org/problem?id=1988 题意:有n个箱子,初始时每个箱子单独为一列: 接下来有p行输入,M, x, y 或者 C, x: 对于M,x,y:表示将x箱子所 ...
- 自动复制转换StringBuffer
自动复制转换StringBuffer http://www.cnblogs.com/coqn/archive/2012/07/31/all_StringBuufer.html http://blog. ...
- Extjs ComboBox 动态选中第一项
有时候我们希望通过Store加载过来的数据,ComboBoxItem能够选择第一条数据作为默认数据,我们可以这么操作: var storeinfo = Ext.create('Ext.data.Sto ...
- tornado web高级开发项目之抽屉官网的页面登陆验证、form验证、点赞、评论、文章分页处理、发送邮箱验证码、登陆验证码、注册、发布文章、上传图片
本博文将一步步带领你实现抽屉官网的各种功能:包括登陆.注册.发送邮箱验证码.登陆验证码.页面登陆验证.发布文章.上传图片.form验证.点赞.评论.文章分页处理以及基于tornado的后端和ajax的 ...