[CTSC2008]祭祀river

Time Limit: 10 Sec  Memory Limit: 162 MB
Submit: 2175  Solved: 1098
[Submit][Status][Discuss]

Description

  在遥远的东方,有一个神秘的民族,自称Y族。他们世代居住在水面上,奉龙王为神。每逢重大庆典, Y族都
会在水面上举办盛大的祭祀活动。我们可以把Y族居住地水系看成一个由岔口和河道组成的网络。每条河道连接着
两个岔口,并且水在河道内按照一个固定的方向流动。显然,水系中不会有环流(下图描述一个环流的例子)。
  由于人数众多的原因,Y族的祭祀活动会在多个岔口上同时举行。出于对龙王的尊重,这些祭祀地点的选择必
须非常慎重。准确地说,Y族人认为,如果水流可以从一个祭祀点流到另外一个祭祀点,那么祭祀就会失去它神圣
的意义。族长希望在保持祭祀神圣性的基础上,选择尽可能多的祭祀的地点。

Input

  第一行包含两个用空格隔开的整数N、M,分别表示岔口和河道的数目,岔口从1到N编号。接下来M行,每行包
含两个用空格隔开的整数u、v,描述一条连接岔口u和岔口v的河道,水流方向为自u向v。 N ≤ 100 M ≤ 1 000

Output

  第一行包含一个整数K,表示最多能选取的祭祀点的个数。

Sample Input

4 4
1 2
3 4
3 2
4 2

Sample Output

2

【样例说明】
在样例给出的水系中,不存在一种方法能够选择三个或者三个以上的祭祀点。包含两个祭祀点的测试点的方案有两种:
选择岔口1与岔口3(如样例输出第二行),选择岔口1与岔口4。
水流可以从任意岔口流至岔口2。如果在岔口2建立祭祀点,那么任意其他岔口都不能建立祭祀点
但是在最优的一种祭祀点的选取方案中我们可以建立两个祭祀点,所以岔口2不能建立祭祀点。对于其他岔口
至少存在一个最优方案选择该岔口为祭祀点,所以输出为1011。

HINT

 题解:一开始没看出来是二分图的裸题,我以为是并查集,然后Tarjan方面去思考问题了,
结果就是最大独立集,看起来概念,性质没有好好理解,对了还需要求一下传递闭包

 #include<cstdio>
#include<cstring>
#include<cmath>
#include<iostream>
#include<algorithm>
#define N 2007 using namespace std; int a[N][N],lk[N],f[N][N];
bool vis[N];
int n,m; bool find(int x)
{
for (int i=;i<=n;i++)
if (a[x][i] && !vis[i])
{
vis[i]=;
if (!lk[i]||find(lk[i]))
{
lk[i]=x;
return ;
}
}
return ;
} int main()
{
scanf("%d%d",&n,&m);
for (int i=;i<=m;i++)
{
int x,y;
scanf("%d%d",&x,&y);
f[x][y]=;
}
for (int k=;k<=n;k++)
for (int i=;i<=n;i++)
for (int j=;j<=n;j++)
f[i][j]|=f[i][k]&&f[k][j];
for (int i=;i<=n;i++)
for (int j=;j<=n;j++)
if (f[i][j] && i!=j) a[i][j]=;
int ans=n;
for (int i=;i<=n;i++)
{
memset(vis,,sizeof(vis));
if (find(i)) ans--;
}
printf("%d\n",ans);
}

 

最新文章

  1. 阿里云服务器Linux CentOS安装配置(十)安装Discuz
  2. 工程中建立多个src目录
  3. 用.htaccess获取文件夹和文件名
  4. How Tomcat Works读书笔记之升级架构
  5. 华为荣耀6PLUS 秒杀苹果
  6. Bootstrap--组件之按钮组
  7. Mac 把图片反色
  8. 使用java求高精度除法,要求保留N位小数
  9. SPJ
  10. 递归---NYOJ-90整数划分(一)
  11. Linux sar使用
  12. qt5.6 for android
  13. 阿里巴巴Java开发手册快速学习
  14. vim命令:编辑模式和命令模式
  15. 南大算法设计与分析课程复习笔记(3)L3 - Recursion
  16. 矩震级Mw与地震矩M0的换算关系
  17. TOEIC真题学习
  18. Java -- 异常的捕获及处理 -- 范例 -- throw与throws的应用
  19. 抽象类(abstract class)
  20. VUE入门准备------&gt;ES6

热门文章

  1. java中求几个字符串的最大公共子串 使用了比较器Comparator
  2. Js 数组去重的几种方法总结
  3. Element表单验证(2)
  4. poj3525 Most Distant Point from the Sea
  5. PAT 乙级 1045
  6. codis 配置
  7. Python正则表达式详解——re库
  8. 重写laravel 异常抛出处理
  9. 下载旧版本的JDK
  10. 转载:使用Pandas进行数据匹配