hdoj1827
图的强连通,缩点,求个入度为0的点的数量,和入度为0的点集里面最小的花费和。
//很死板的题,模板题的一样的…
#include<cstdio>
#include<queue>
#include<iostream>
#include<string.h>
#include<algorithm>
using namespace std;
typedef long long LL;
#define INF 9999999
#define mod 1000000007
#define N 1050
typedef long long LL;
struct asd{
int to;
int next;
};
asd q[N*2];
int head[N*2];
int tol;
int low[N];
int dfn[N];
bool vis[N];
int n,m;
int sta[N];
int cost[N];
int in[N];
int incos[N];
int ru[N];
int tp,p;
int sum;
void tarjan(int u)
{
dfn[u]=low[u]=++tp;
sta[++p]=u;
vis[u]=1;
for(int k=head[u];k!=-1;k=q[k].next)
{
int i=q[k].to;
if(!dfn[i])
{
tarjan(i);
low[u]=min(low[i],low[u]);
}
else if(vis[i])
{
low[u]=min(low[u],dfn[i]);
}
}
if(dfn[u]==low[u])
{
++sum;
int temp;
while(1)
{
temp=sta[p];
vis[temp]=0;
in[temp]=sum;
incos[sum]=min(incos[sum],cost[temp]);
p--;
if(temp==u)
{
break;
}
}
}
}
void solve_rudu()
{
memset(ru,0,sizeof(ru));
for(int i=1;i<=n;i++)
{
for(int k=head[i];k!=-1;k=q[k].next)
{
int ss=q[k].to;
if(in[ss]!=in[i])
ru[in[ss]]++;
}
}
int ans=0;
int ccs=0;
for(int i=1;i<=sum;i++)
{
if(!ru[i])
{
ans++;
ccs+=incos[i];
}
}
printf("%d %d\n",ans,ccs);
}
void init()
{
tol=0;
memset(dfn,0,sizeof(dfn));
memset(head,-1,sizeof(head));
memset(vis,0,sizeof(vis));
memset(incos,INF,sizeof(incos));
}
void add(int a,int b)
{
q[tol].to=b;
q[tol].next=head[a];
head[a]=tol++;
}
int main()
{
while(~scanf("%d%d",&n,&m))
{
for(int i=1;i<=n;i++)
{
scanf("%d",&cost[i]);
}
init();
for(int i=0;i<m;i++)
{
int a,b;
scanf("%d%d",&a,&b);
add(a,b);
}
sum=tp=p=0;
for(int i=1;i<=n;i++)
{
if(!dfn[i])
{
tarjan(i);
}
}
solve_rudu();
}
}
hdoj1827的更多相关文章
- [HDOJ1827]Summer Holiday(强连通分量,缩点)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1827 缩点后统计入度和当前强连通分量中最小花费,然后记录入度为0的点的个数和花费和就行了. /* ━━ ...
随机推荐
- QEMU+GDB调试方法
两年前调试usb/ip开源项目时,就曾用虚拟机远程调试过Windows和Linux系统内核,当时在VMware Workstation上创建两个虚拟机进行调试,也没有记录下如何配置调试,只是大体的还记 ...
- GTK入门学习:布局容器之水平布局
假设我们希望窗体里多放加入几个控件,直接加入是不成功的.由于窗体仅仅能容纳一个控件的容器. 这时候.我们须要借助布局容器,我们先把布局容器加入到窗体里.然后再把所须要加入的控件放在布局容器里. 布局容 ...
- 基于PHP函数的alert弹框
可以设置弹出信息,跳转地址,跳转的时间,跳转的信息标题提示: 手机端加上<meta name='viewport' content='width=device-width, initial-sc ...
- Android版DesiredCapabilities参数配置
前言 每一个App测试都应指定是在什么平台下,那个设备中运行那个App,而在Appium中主要是通过DesiredCapabilities来配置的. DesiredCapabilities的作用,负责 ...
- Xamarin.Android 实现虾米音乐搜索下载
之前写过一篇博客,用api接口实现虾米音乐搜索功能,不过这个api接口被封了,所以只能获取到官方的一个音乐json数据,里面的下载地址是被加密过得,这里我会教大家如何用xamarin实现. 准备工作: ...
- Smoke testing (software)
Smoke testing (software) - Wikipedia https://en.wikipedia.org/wiki/Smoke_testing_(software) In compu ...
- NIO原理图
- C# 自定义控件及引用自动义控件
1.http://www.cnblogs.com/hjxzjp/p/7823292.html 优先考虑从现有的控件中进行派生,并添加所需要的功能. 在解决方案资源管理器窗口中设置:引用----&g ...
- oracle case where 复杂sql语句
update hr_user u set u.is_approve=(case when u.curr_org_id in (select t.org_id from hr_organization ...
- (C)strcpy ,strncpy和strlcpy的基本用法
好多人已经知道利用strncpy替代strcpy来防止缓冲区越界. 但是如果还要考虑运行效率的话,也许strlcpy是一个更好的方式. 1. strcpy strcpy 是依据 /0 作为结束判断的, ...