1827 tarjan+缩点
#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+缩点的更多相关文章
- hihoCoder 1185 连通性·三(Tarjan缩点+暴力DFS)
#1185 : 连通性·三 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 暑假到了!!小Hi和小Ho为了体验生活,来到了住在大草原的约翰家.今天一大早,约翰因为有事要出 ...
- POJ 1236 Network of Schools(Tarjan缩点)
Network of Schools Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 16806 Accepted: 66 ...
- King's Quest —— POJ1904(ZOJ2470)Tarjan缩点
King's Quest Time Limit: 15000MS Memory Limit: 65536K Case Time Limit: 2000MS Description Once upon ...
- 【BZOJ-2438】杀人游戏 Tarjan + 缩点 + 概率
2438: [中山市选2011]杀人游戏 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1638 Solved: 433[Submit][Statu ...
- 【BZOJ-1924】所驼门王的宝藏 Tarjan缩点(+拓扑排序) + 拓扑图DP
1924: [Sdoi2010]所驼门王的宝藏 Time Limit: 5 Sec Memory Limit: 128 MBSubmit: 787 Solved: 318[Submit][Stat ...
- 【BZOJ-1797】Mincut 最小割 最大流 + Tarjan + 缩点
1797: [Ahoi2009]Mincut 最小割 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1685 Solved: 724[Submit] ...
- BZOJ 1051 受欢迎的牛(Tarjan缩点)
1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec Memory Limit: 162 MB Submit: 4573 Solved: 2428 [Submit][S ...
- HDU4612+Tarjan缩点+BFS求树的直径
tarjan+缩点+树的直径题意:给出n个点和m条边的图,存在重边,问加一条边以后,剩下的桥的数量最少为多少.先tarjan缩点,再在这棵树上求直径.加的边即是连接这条直径的两端. /* tarjan ...
- POJ 1236 Network of Schools(强连通 Tarjan+缩点)
POJ 1236 Network of Schools(强连通 Tarjan+缩点) ACM 题目地址:POJ 1236 题意: 给定一张有向图,问最少选择几个点能遍历全图,以及最少加入�几条边使得 ...
随机推荐
- Java经典算法之折半查找(二分法)
采用二分法时,数据应是有序并且不重复的 与小时候玩的猜数游戏是一样的,会让你猜一个他所想的1~100之间的数,当你猜了一个数后,他会告诉你三种选择中的一个,比他想的大,或小,或猜中了,为了能用最少的次 ...
- jQuery——表单应用(4)
HTML: <!--复选框应用--> <!DOCTYPE html> <html> <head> <meta charset="UTF- ...
- SQL 经典语句大全
原地址:http://www.cnblogs.com/yubinfeng/archive/2010/11/02/1867386.html 一.基础 1.说明:创建数据库 CREATE DATABASE ...
- 常用点击事件(鼠标、光标、键盘、body)
常用事件: 鼠标: onclick(单击) ondblclick(双击) oncontextmenu(右击) onmouseover onmouseout 光标: onfocus onblur 键盘: ...
- Windows 7上安装Microsoft Loopback Adapter(微软环回网卡)
Oracle 安装过程中,先决条件检查遇到如下错误: 正在检查网络配置要求... 检查完成.此次检查的总体结果为: 失败 <<<< 问题: 安装检测到系统的主 IP 地址是 ...
- 235 Lowest Common Ancestor of a Binary Search Tree 二叉搜索树的最近公共祖先
给定一棵二叉搜索树, 找到该树中两个指定节点的最近公共祖先. 详见:https://leetcode.com/problems/lowest-common-ancestor-of-a-binary-s ...
- ubuntu系统nginx+Redis+PHP
一.安装ngnix apt-get update sudo apt-get install nginx /etc/init.d/nginx start 二.安装php sudo apt-get ins ...
- golang 自定义time.Time json输出格式
工作中使用golang时,遇到了一个问题.声明的struct含time.Time类型.使用json格式化struct时,time.Time被格式化成”2006-01-02T15:04:05.99999 ...
- HDU_1584_(DFS)
蜘蛛牌 Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- CAD控件:控件图形数据库概要说明
1.1 控件数据库 3 1.1.1 数据库概述 3 1.2 数据库初始化 4 1.3 创建和组织数据库 4 1.4 保存数据库 4 1.5 插入一个数据库 4 1.6 设置当前数据库值 5 1.6.1 ...