nyoj--120--校园网络(scc+缩点)

校园网络

时间限制:3000 ms  |  内存限制:65535 KB
难度:5
描述

南阳理工学院共有M个系,分别编号1~M,其中各个系之间达成有一定的协议,如果某系有新软件可用时,该系将允许一些其它的系复制并使用该软件。但该允许关系是单向的,即:A系允许B系使用A的软件时,B未必一定允许A使用B的软件。

现在,请你写一个程序,根据各个系之间达成的协议情况,计算出最少需要添加多少个两系之间的这种允许关系,才能使任何一个系有软件使用的时候,其它所有系也都有软件可用。

输入
第一行输入一个整数T,表示测试数据的组数(T<10)
每组测试数据的第一行是一个整数M,表示共有M个系(2<=M<=100)。
随后的M行,每行都有一些整数,其中的第i行表示系i允许这几个系复制并使用系i的软件。每行结尾都是一个0,表示本行输入结束。如果某个系不允许其它任何系使用该系软件,则本行只有一个0.
输出
对于每组测试数据,输出最少需要添加的这种允许关系的个数。
样例输入
1
5
2 4 3 0
4 5 0
0
0
1 0
样例输出
2
来源
POJ改编
上传者

张云聪


<pre name="code" class="cpp">#include<stdio.h>
#include<string.h>
#include<queue>
#include<stack>
#include<vector>
#include<algorithm>
using namespace std;
#define MAXN 50010
int in[MAXN],out[MAXN],sumin,sumout;
vector<int>G[MAXN];
vector<int>scc[MAXN];
struct node
{int u,v;int next;
}edge[MAXN];
int head[MAXN],cnt,scc_cnt,dfs_clock;
int sccno[MAXN],low[MAXN],dfn[MAXN];
bool Instack[MAXN];
int n;
stack<int>s;
void init()
{memset(head,-1,sizeof(head));cnt=0;
}
void add(int u,int v)
{node E={u,v,head[u]};edge[cnt]=E;head[u]=cnt++;
}
void getmap()
{for(int i=1,a;i<=n;i++){while(scanf("%d",&a),a)add(i,a);}
}
void suodian()
{for(int i=1;i<=scc_cnt;i++)G[i].clear(),in[i]=0,out[i]=0;for(int i=0;i<n;i++){int u=sccno[edge[i].u];int v=sccno[edge[i].v];if(u!=v)out[u]++,in[v]++;}
}
void tarjan(int u,int fa)
{int v;low[u]=dfn[u]=++dfs_clock;s.push(u);Instack[u]=true;for(int i=head[u];i!=-1;i=edge[i].next){v=edge[i].v;if(!dfn[v]){tarjan(v,u);low[u]=min(low[u],low[v]);}else if(Instack[v])low[u]=min(low[u],dfn[v]);}if(dfn[u]==low[u]){scc_cnt++;scc[scc_cnt].clear();for(;;){v=s.top();s.pop();Instack[v]=false;sccno[v]=scc_cnt;scc[scc_cnt].push_back(v);if(u==v) break;}}
}
void solve()
{sumin=sumout=0;if(scc_cnt==1)printf("0\n");else{for(int i=1;i<=scc_cnt;i++){if(in[i]==0) sumin++;if(out[i]==0) sumout++;}int sum=max(sumin,sumout);printf("%d\n",sum);}
}
void find(int l,int r)
{memset(Instack,false,sizeof(Instack));memset(low,0,sizeof(low));memset(dfn,0,sizeof(dfn));memset(sccno,0,sizeof(sccno));dfs_clock=scc_cnt=0;for(int i=l;i<=r;i++)if(!dfn[i])tarjan(i,-1);
}
int main()
{int t;scanf("%d",&t);while(t--){init();scanf("%d",&n);getmap();find(1,n);suodian();solve();}
}


 
 

转载于:https://www.cnblogs.com/playboy307/p/5273529.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/272460.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SQL的四种连接用法整理

1、内联接&#xff08;典型的联接运算&#xff0c;使用像 或 <> 之类的比较运算符&#xff09;。包括相等联接和自然联接。 内联接使用比较运算符根据每个表共有的列的值匹配两个表中的行。例如&#xff0c;检索 students和courses表中学生标识号相同的所有行。 …

简述 OAuth 2.0 的运作流程

本文将以用户使用 github 登录网站留言为例&#xff0c;简述 OAuth 2.0 的运作流程。 假如我有一个网站&#xff0c;你是我网站上的访客&#xff0c;看了文章想留言表示「朕已阅」&#xff0c;留言时发现有这个网站的帐号才能够留言&#xff0c;此时给了你两个选择&#xff1a;…

linux库引入之动态库静态库(生成和使用)

库&#xff1a; 库是一种可执行代码的二进制形式&#xff0c;可以被操作系统载入内存执行。就是将源代码转化为二进制格式的源代码&#xff0c;相当于进行了加密&#xff0c;别人可以使用库&#xff0c;但是看不到库中的内容。 如何使用 用户需要同时具有头文件和库。 头文件…

InstallShield limited edition 生成单个 setup.exe 安装文件

InstallShield limited edition 生成单个 setup.exe 安装文件 1.vs里选中当前Setup项目, 2.在vs工具栏中"配置管理器"的下拉列表里,把"Debug"改为"SingleImage" 3.重新编译 posted on 2016-01-14 09:45 NET未来之路 阅读(...) 评论(...) 编辑 收…

ASP.NET中高级程序员 面试题

第一部分&#xff1a;互相介绍及了解1.请介绍一下你自己?包括工作经历和项目经历&#xff1f;2.请谈一下你就最近的一个项目&#xff1f;你在其中的职责和负责的部分?第二部分&#xff1a;一、ASP.NET技术问题选择性提问。一般可以选择三五个。1. 简要说一下.Net的编译过程.2…

gettimeofday函数

定义&#xff1a; gettimeofday是计算机函数&#xff0c;使用C语言编写程序需要获得当前精确时间&#xff08;1970年1月1日到现在的时间&#xff09;&#xff0c;或者为执行计时&#xff0c;可以使用gettimeofday()函数。 使用方法&#xff1a; #include <sys/time.h> i…

SQL Server数据库设置自动备份策略

一. 简单介绍SQL Server自带的维护计划是一个非常有用的维护工具&#xff0c;能够完成大部分的数据库的维护任务.数据库的备份也是日常工作中非常重要的一个环节。备份的方法非常的多.今天给大家介绍最简单的一种方法: 直接通过SQL Server Management Studio的图形界面去设置备…

C3P0在多线程下的maxPoolSize配置

ETL工具完毕的差点儿相同了。今天遇到一个问题。就是给C3P0配置了maxPoolSize为10。目的是想让整个应用同一时候获得的最大的Connection个数为10&#xff0c;可是在測试应用的这一部分之后&#xff0c;发现PostgreSQL端的链接远远超过10个。由于工具是多线程的。所以就想&#…

树莓派外设开发编程

树莓派外设开发接口文档参考 wiringPi&#xff08;特定平台&#xff0c;特定功能接口&#xff09; 库&#xff08;linux 动态库 静态库&#xff09; gcc demo1.c -lwiringPi //编译时要加-lwiringPigpio -v //查看是否安装wiringPi库 gpio version: 2.50 Copyright (c) 2012-2…

Bootstrap 5款常用模板

篇文章中&#xff0c;我们已经编制了5款最好的 Bootstrap 4.0 主题模板清单&#xff0c;让您可以用在下一个项目中&#xff0c;我们希望你能找到有用的。这些主题包含了所有必要的 HTML 和 CSS 为基础的设计模板的版式&#xff0c;表单&#xff0c;按钮&#xff0c;导航和其它界…

工作内外网同时连接方案

需求 工作的时候需要用到外网查询资料&#xff0c;又需要用内网完成工作任务。不想来回切换网络。 前提 外网使用无线&#xff0c;内网使用水晶头接口。 方案 1.插入水晶头接口&#xff08;效果是连接内网&#xff09;。 2.进入 → “控制面板\网络和 Internet\网络和共享中心”…

三种常用图片格式的使用场景

GIF&#xff1a;1&#xff1a;256色2&#xff1a; 无损&#xff0c;编辑 保存时候&#xff0c;不会损失。3&#xff1a;支持简单动画。4&#xff1a;支持boolean透明&#xff0c;也就是要么完全透明&#xff0c;要么不透明JPEG&#xff1a;1&#xff1a;millions of colors2&am…

交叉编译及树莓派(或其他平台)交叉编译工具链的安装

交叉编译是什么&#xff1a; 交叉编译是一个行为&#xff0c;是在一个平台上生成另一个平台上的可执行代码。 比如&#xff1a;我们在windows上面编写C51的代码&#xff0c;并编译成可执行代码&#xff0c;如xx.hex,是在C51上面运行不是在windows上面运行。 同样&#xff1a;我…

Delphi:ADOConnection连接SQLServer自动断网问题解决

解决方法一&#xff1a;异常时关闭连接&#xff0c;WinXP&#xff0c;win7 32位大部分情况都是起作用的&#xff0c;不过在有些windows操作系统下&#xff08;如家庭版&#xff09;不起作用&#xff0c;不知为何&#xff1f; try //执行sql操作 except AdoConnection.close;//…

走近北京后厂村程序员的真实生活

来源&#xff1a;中新经纬北京的西北角是个特别的区域&#xff0c;这里汇集了众多互联网及IT企业&#xff0c;实力雄厚的上市公司将自家 logo 悬挂在大厦的顶端&#xff0c;而刚起步的创业公司也会选择在这里租下一亩三分地。中关村、上地、西二旗、后厂村……它们成为了一个个…

带wiringPi库的交叉编译

WiringPi的下载——网盘提取 链接&#xff1a;https://pan.baidu.com/s/1cPIt-xZLye1DAQjq2yKzeg 提取码&#xff1a;35vt &#xff08;这个库不是很好&#xff0c;链接的库的格式不对&#xff0c;是宿主机的平台&#xff0c;需要自己将树莓派的wiringpi库&#xff08;libwiri…

lintcode:最小编辑距离

最小编辑距离 给出两个单词word1和word2&#xff0c;计算出将word1 转换为word2的最少操作次数。 你总共三种操作方法&#xff1a; 插入一个字符删除一个字符替换一个字符样例 给出 work1"mart" 和 work2"karma" 返回 3 解题 动态规划解题 定义矩阵dp[][]…

这些代码优化的方法,你都用过吗?

来自&#xff1a;www.cnblogs.com/xrq730/代码优化的最重要的作用应该是&#xff1a;避免未知的错误在代码上线运行的过程中&#xff0c;往往会出现很多我们意想不到的错误&#xff0c;因为线上环境和开发环境是非常不同的&#xff0c;错误定位到最后往往是一个非常小的原因。然…

VMwareTool 安装

VMwareTools的一些实用性 安装后用户可以从物理主机直接往虚拟机里面拖文件。 安装后鼠标进入虚拟机后可以直接出来&#xff0c;不安装的话要按CTRLALT才可以释放鼠标。 安装后可以解决Ubuntu主窗口分辨率不适应问题&#xff0c;用户可以随意改变虚拟机窗口大小&#xff0c;vm…

Yann LeCun, Geoffrey E. Hinton, and Yoshua Bengio

转载于:https://www.cnblogs.com/hanhuilee/p/5221255.html