POJ 1236 Networks of School Tarjan 基础
题目大意:
给一个有向图,一个文件可以从某个点出发传递向他能连的边
现在有两个问题
1.至少需要多少个放文件可以让整个图都有文件
2.可以进行一个操作:给一对点(u,v)连一条u->v的有向边,问至少需要多少次操作,才能使任意一个点放的文件都能传递到整个图
题解:
先tarjan缩个点
对于1. 找入度为0的强联通分量的个数
对于2.取出度和入度为0的强联通分量的个数的较大值(如果只有一个,显然是0)
- #include<cstdio>
- #include<algorithm>
- #include<cstring>
- #include<vector>
- #include<stack>
- #define M 50010
- #define N 10010
- using namespace std;
- int n,m,u,v,head[N],cnt=,ans,in[N],belong[N],dfn[N],low[N],indx,tar,out[N];
- bool inst[N];
- stack <int> st;
- struct edge
- {
- int u,v;
- }e[M];
- void add(int u,int v)
- {
- e[cnt].v=v;
- e[cnt].u=head[u];
- head[u]=cnt++;
- }
- void dfs(int u)
- {
- dfn[u]=low[u]=++indx;
- inst[u]=;
- st.push(u);
- for (int i=head[u];i;i=e[i].u)
- {
- int v=e[i].v;
- if(!dfn[v])
- {
- dfs(v);
- low[u]=min(low[u],low[v]);
- }
- else
- if (inst[v])
- low[u]=min(low[u],dfn[v]);
- }
- if (dfn[u]==low[u])
- {
- tar++;
- while ()
- {
- int t=st.top();
- st.pop(),inst[t]=;
- belong[t]=tar;
- if (t==u)
- break;
- }
- }
- }
- int main()
- {
- scanf("%d",&n);
- for (int i=;i<=n;i++)
- {
- int j;
- while (scanf("%d",&j)!=EOF && j!=)
- add(i,j);
- }
- for (int i=;i<=n;i++)
- if (dfn[i]==) dfs(i);
- for (int i=;i<=n;i++)
- for (int j=head[i];j;j=e[j].u)
- {
- int v=e[j].v;
- if (belong[i]!=belong[v])
- {
- // printf("%d %d\n",i,v);
- in[belong[v]]++;
- out[belong[i]]++;
- }
- }
- for (int i=;i<=tar;i++)
- if (in[i]==) ans++;
- printf("%d\n",ans);
- int ans2=;
- for (int i=;i<=tar;i++)
- if (out[i]== && tar>) ans2++;
- if (tar==) ans=;
- printf("%d\n",max(ans,ans2));
- return ;
- }
POJ 1236 Networks of School Tarjan 基础的更多相关文章
- Poj 1236 Network of Schools (Tarjan)
题目链接: Poj 1236 Network of Schools 题目描述: 有n个学校,学校之间有一些单向的用来发射无线电的线路,当一个学校得到网络可以通过线路向其他学校传输网络,1:至少分配几个 ...
- POJ 1236 Network of Schools (Tarjan + 缩点)
Network of Schools Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 12240 Accepted: 48 ...
- [poj] 1236 networks of schools
原题 这是一道强连通分量板子题. 显然subtask1 是要输出入度为0的点的个数 而subtask2,我们考虑一下最优一定是把一个出度为零的点连到入度为零的点上,这样我们要输出的就是max(出度为零 ...
- POJ 1236 Network of Schools Tarjan缩点
Network of Schools Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 22729 Accepted: 89 ...
- poj 2186: Popular Cows(tarjan基础题)
题目链接 tarjan参考博客 题意:求在图上可以被所有点到达的点的数量. 首先通过tarjan缩点,将所有内部两两可达的子图缩为一点,新图即为一个有向无环图(即DAG). 在这个DAG上,若存在不止 ...
- POJ 3180 The cow Prom Tarjan基础题
题目用google翻译实在看不懂 其实题目意思如下 给一个有向图,求点个数大于1的强联通分量个数 #include<cstdio> #include<algorithm> #i ...
- POJ 1236 Network of Schools(Tarjan缩点)
Network of Schools Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 16806 Accepted: 66 ...
- POJ 1236 Network of Schools(强连通 Tarjan+缩点)
POJ 1236 Network of Schools(强连通 Tarjan+缩点) ACM 题目地址:POJ 1236 题意: 给定一张有向图,问最少选择几个点能遍历全图,以及最少加入�几条边使得 ...
- POJ 1236 Network of Schools - 缩点
POJ 1236 :http://poj.org/problem?id=1236 参考:https://www.cnblogs.com/TnT2333333/p/6875680.html 题意: 有好 ...
随机推荐
- BZOJ4128: Matrix(BSGS 矩阵乘法)
Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 813 Solved: 442[Submit][Status][Discuss] Descriptio ...
- Python 对象(type/object/class) 作用域 一等函数 (慕课--Python高级,IO并发 第二章)
在python中一共有两种作用域:全局作用域和函数作用域全局作用域:在全局都有效,全局作用域在程序执行时创建,在程序执行结束时销毁:所有函数以外的区域都是全局作用域:在全局作用域中定义的变量,都属于全 ...
- order-by-offset-fetch
- iOS-修改modal出来的控制器的大小
- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{ static BOOL sh ...
- Android面试收集录13 Android虚拟机及编译过程
一.什么是Dalvik虚拟机 Dalvik是Google公司自己设计用于Android平台的Java虚拟机,它是Android平台的重要组成部分,支持dex格式(Dalvik Executable)的 ...
- TouTiao开源项目 分析笔记14 段子评论
1.段子页面详情 1.1.先看看预览界面吧 左边的页面已经实现了,现在的目的就是要实现点击左侧的每一个item 然后跳转到右边相应的段子详情页面. 1.2.首先肯定有右侧这个活动==>JokeC ...
- 3,Python常用库之三:Matplotlib
一.Matplotlib基础知识 Matplotlib中的基本图表包括的元素 x轴和y轴 axis水平和垂直的轴线 x轴和y轴刻度 tick刻度标示坐标轴的分隔,包括最小刻度和最大刻度 x轴和y轴刻度 ...
- 非阻塞IO模板
服务端 from socke import * server = socket(AF_INET, SOCK_STREAM) server.bind(('127.0.0.1',8083)) server ...
- JSONP解决跨域完整例子
1.这个案例是仿照百度搜索,输入关键词,会出现下拉菜单的过程. 效果: 2.具体做法: (1)利用百度的数据库做script标签的src. 复制之后的地址是这样的 https://sp0.baidu. ...
- 《Cracking the Coding Interview》——第1章:数组和字符串——题目5
2014-03-18 01:40 题目:对字符串进行类似游程编码的压缩,如果压缩完了长度更长,则返回不压缩的结果.比如:aabcccccaaa->a2b1c5a3,abc->abc. 解法 ...