#include<stdio.h>

#include<stack>

#include<iostream>

#include<string.h>

#include<vector>

#include<string>

using namespace std;

#define inf 1000000000

#define N 2100

vector<int>h[N];//

stack<int>q;///

int dfn[N],low[N],index,indegree[N],a[N],visit[N],suo[N],fee[N],yong;

int min(int a,int b) {

return a>b?b:a;

}

void tarjan(int u) {

int i;

dfn[u]=low[u]=++index;

visit[u]=1;

q.push(u);

for(i=0;i<h[u].size();i++) {

int v=h[u][i];

if(!dfn[v]) {

tarjan(v);

low[u]=min(low[u],low[v]);//

}

else

if(visit[v]==1) //在寨中

low[u]=min(low[u],low[v]);

}

if(dfn[u]==low[u]) {//如果存在一个强连通分量就将里面的出寨

yong++;

int t;

do {

   t=q.top();

q.pop();

visit[t]=2;//已经浏览过了

suo[t]=yong;//讲一个连通分量置为一个点

            if(fee[yong]>a[t])//求出缩点中最小的费用

fee[yong]=a[t];

}while(t!=u);



}

}

int main() {

int n,m,i,j,count,num;

while(scanf("%d%d",&n,&m)!=EOF) {

while(!q.empty()) 

q.pop();

for(i=1;i<=n;i++) {//输入和初始化

scanf("%d",&a[i]);

h[i].clear();

fee[i]=inf;

}

while(m--) {

scanf("%d%d",&i,&j);//

h[i].push_back(j);//



memset(visit,0,sizeof(visit));

index=0;yong=0;

memset(dfn,0,sizeof(dfn));

memset(low,0,sizeof(low));

for(i=1;i<=n;i++)

if(visit[i]!=2)//是否已经入过寨

tarjan(i);

count=0;

memset(indegree,0,sizeof(indegree));

for(i=1;i<=n;i++) 

for(j=0;j<h[i].size();j++) 

  if(suo[i]!=suo[h[i][j]])//如果不是同一个缩点

  indegree[suo[h[i][j]]]++;

  num=0;

  for(i=1;i<=yong;i++)

  if(indegree[i]==0) {//找入度为零的点

  count+=fee[i];

  num++;

  }

  printf("%d %d\n",num,count);

}

return 0;

}

1827 tarjan+缩点的更多相关文章

  1. hihoCoder 1185 连通性·三(Tarjan缩点+暴力DFS)

    #1185 : 连通性·三 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 暑假到了!!小Hi和小Ho为了体验生活,来到了住在大草原的约翰家.今天一大早,约翰因为有事要出 ...

  2. POJ 1236 Network of Schools(Tarjan缩点)

    Network of Schools Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 16806   Accepted: 66 ...

  3. King's Quest —— POJ1904(ZOJ2470)Tarjan缩点

    King's Quest Time Limit: 15000MS Memory Limit: 65536K Case Time Limit: 2000MS Description Once upon ...

  4. 【BZOJ-2438】杀人游戏 Tarjan + 缩点 + 概率

    2438: [中山市选2011]杀人游戏 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1638  Solved: 433[Submit][Statu ...

  5. 【BZOJ-1924】所驼门王的宝藏 Tarjan缩点(+拓扑排序) + 拓扑图DP

    1924: [Sdoi2010]所驼门王的宝藏 Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 787  Solved: 318[Submit][Stat ...

  6. 【BZOJ-1797】Mincut 最小割 最大流 + Tarjan + 缩点

    1797: [Ahoi2009]Mincut 最小割 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 1685  Solved: 724[Submit] ...

  7. BZOJ 1051 受欢迎的牛(Tarjan缩点)

    1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec  Memory Limit: 162 MB Submit: 4573  Solved: 2428 [Submit][S ...

  8. HDU4612+Tarjan缩点+BFS求树的直径

    tarjan+缩点+树的直径题意:给出n个点和m条边的图,存在重边,问加一条边以后,剩下的桥的数量最少为多少.先tarjan缩点,再在这棵树上求直径.加的边即是连接这条直径的两端. /* tarjan ...

  9. POJ 1236 Network of Schools(强连通 Tarjan+缩点)

    POJ 1236 Network of Schools(强连通 Tarjan+缩点) ACM 题目地址:POJ 1236 题意:  给定一张有向图,问最少选择几个点能遍历全图,以及最少加入�几条边使得 ...

随机推荐

  1. [Swift通天遁地]一、超级工具-(16)使用JTAppleCalendar制作美观的日历

    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...

  2. 乐搏讲自动化测试-python语言特点及优缺点(5)

    相信小伙伴们都知道,随着软件测试行业的发展和进步自动化测试已经成为必然.在竞争日益激烈的市场环境中也是你升职加薪的利器. 所以,小编决定从今天起!将要系统.连续.高质量的持续更新「整套自动化测试」文章 ...

  3. Android 性能优化(23)*性能工具之「Heap Viewer, Memory Monitor, Allocation Tracker」Memory Profilers

    Memory Profilers In this document Memory Monitor Heap Viewer Allocation Tracker You should also read ...

  4. 402 Remove K Digits 移掉K位数字

    给定一个以字符串表示的非负整数 num,移除这个数中的 k 位数字,使得剩下的数字最小.注意:    num 的长度小于 10002 且 ≥ k.    num 不会包含任何前导零.示例 1 :输入: ...

  5. 选择语言之switch case

    程序语言-选择语言之switch   case 多选一,类似if    else if  else if  else 模版: Switch(选择条件) { Case(条件一)//相当于if Conso ...

  6. es6之iterator,for...of

    遍历器(Iterator)是一种统一的接口机制,来处理所有不同的数据结构. JavaScript 原有的表示“集合”的数据结构,主要是数组(Array)和对象(Object),ES6 又添加了Map和 ...

  7. UNICODE本地编译freescale的i.MX6Q的android4.2.2&android4.4.2 && 全志a80的步骤x1

    20151031本地编译freescale的i.MX6Q的android4.2.2&android4.4.2 && 全志a80的步骤x1 2015/10/31 15:07 开始 ...

  8. dive into python:模块的导入和搜索文件路径的配置

    1.Python中导入模块:import sys:相当于Java中的导入包.类. 比如,我们导入sys模块,使用:import sys; 2.Python中调用函数的时候,会从默认配置的库文件夹中(s ...

  9. json-server模拟REST API

    介绍 可以开启一个服务前端使用 安装 npm i json-server -g 使用 $ json-server db.json -p 3000 // 在文件目录下执行上述命令,开放一个端口3000的 ...

  10. dutacm.club_1087_Common Substrings_(KMP)_(结合此题通俗理解kmp的next数组)

    1087: Common Substrings Time Limit:3000/1000 MS (Java/Others)   Memory Limit:163840/131072 KB (Java/ ...