【FOJ2210 11月月赛F】【DFS or 拓扑排序】攻占计划 n个点m条边DAG破坏一个点使得不可达点数尽可能多

原创 2015年11月18日 19:37:48
 Problem 2210 攻占计划

Accept: 20    Submit: 28
Time Limit: 1000 mSec    Memory Limit : 131072 KB

 Problem Description

A国和B国正在进行一场战争,A国有n座城市,这些城市被m条有向道路相连,这些道路不会形成环路。其中有一部分城市比较特殊,其拥有粮仓,拥有粮仓的城市不能被其他城市到达,粮食可以从粮仓经过一些道路送往任意一座城市,现在B国的国王想要破坏一座A国的城市,粮食不能经过被破坏的城市。问破坏哪一座城市,可以使得最多的城市断粮。

 Input

第一行两个数n和m(n<=1000,m<=10000)

接下来m行,每行两个数字a和b,表示城市a有一条连向城市b的道路

 Output

输出一个数,表示被破坏的城市的序号,如果有多个城市满足条件,输出序号最小的那个城市

 Sample Input

3 31 22 31 3

 Sample Output

1

 Source

FOJ有奖月赛-2015年11月


#include<stdio.h> 
#include<string.h>
#include<ctype.h>
#include<math.h>
#include<iostream>
#include<string>
#include<set>
#include<map>
#include<vector>
#include<queue>
#include<bitset>
#include<algorithm>
#include<time.h>
using namespace std;
void fre(){freopen("c://test//input.in","r",stdin);freopen("c://test//output.out","w",stdout);}
#define MS(x,y) memset(x,y,sizeof(x))
#define MC(x,y) memcpy(x,y,sizeof(x))
#define MP(x,y) make_pair(x,y)
#define ls o<<1
#define rs o<<1|1
typedef long long LL;
typedef unsigned long long UL;
typedef unsigned int UI;
template <class T1,class T2>inline void gmax(T1 &a,T2 b){if(b>a)a=b;}
template <class T1,class T2>inline void gmin(T1 &a,T2 b){if(b<a)a=b;}
const int N=1010,M=0,Z=1e9+7,ms63=1061109567;
int n,m,x,y;
int tim,num;
vector<int>a[N],st;
int ind[N],e[N];
void dfs(int x)
{
	if(e[x]==tim)return;
	e[x]=tim;
	--num;
	for(int i=a[x].size()-1;~i;--i)dfs(a[x][i]);
}
int main()
{
	while(~scanf("%d%d",&n,&m))
	{
		int ansnum=0,ansp;
		for(int i=1;i<=n;i++)a[i].clear(),ind[i]=0;
		for(int i=1;i<=m;i++)
		{
			scanf("%d%d",&x,&y);
			a[x].push_back(y);
			++ind[y];
		}
		st.clear();
		for(int i=1;i<=n;i++)if(ind[i]==0)st.push_back(i);
		for(int i=1;i<=n;i++)
		{
			e[i]=++tim;
			num=n;
			for(int j=st.size()-1;~j;--j)dfs(st[j]);
			if(num>ansnum)
			{
				ansnum=num;
				ansp=i;
			}
		}
		printf("%d\n",ansp);
	}
	return 0;
}
/*
【trick&&吐槽】
这道题破坏的不一定是粮仓。
只是因为数据水,所以很容易AC,然而维护逻辑的正确性还是至关重要啊。

【题意】
给你一个n(1000)个点,m(10000)条有向边的 有向无环图。
入度为0的点表示为粮仓,粮仓可以沿着有向边向后输送粮食。
我们要破坏这个图上的某一点。
问你要破坏哪个点,可以使得断粮的城市尽可能多

【类型】
图论

【分析】
向优秀在做法一直想不到,于是干脆暴力,然而就过了。
因为这题点数并不多,枚举点,然后来一遍拓扑排序或dfs,走不到的点计数,更新答案即可AC
有一个我犯蠢的地方就是,还是dfs好写>_<然而我却写了拓扑

【时间复杂度&&优化】
O(n(n+m))

【数据】
5 4
1 3
2 3
3 4
3 5

10 8
1 3
2 3
3 4
3 5

6 7
7 8
8 9
9 10
*/


版权声明:题解中哪里写错请一定要指出来QwQ 转载还请注明下出处哦,谢谢^_^

算法导论22.4拓扑排序 练习总结

22.4-1 给出算法 TOPOLOGICAL-SORT 运行于图 22-8 上时所生成的结点次序。这里的所有假设和练习 22.3-2 一样。 ANSWER: 22.4-2 请给出一个线性时间的算...
  • chan15
  • chan15
  • 2015年12月29日 12:57
  • 6994

【codeforces 721C】【DAG 按照拓扑排序记忆化DFS】C. Journey 【DAG图,5000个点,5000条边 让你求从1到n的路径长度不超过T中经过点数最多的一条 】

传送门:C. Journey 描述: C. Journey time limit per test 3 seconds memory limit ...

【FOJ2205 11月月赛A】【二分图结论题】据说题目很水 n个点上不形成三元环的最大边数

Problem 2205 据说题目很水 Accept: 31    Submit: 58 Time Limit: 1000 mSec    Memory Limit : 32768 KB ...

【hdu 3342】【拓扑排序(DAG) BFS】Legal or Not

传送门:HDU 3342 描述: Legal or Not Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 ...

【HDU5927 2016CCPC东北地区大学生程序设计竞赛 - 重现赛 F】【dfs序 + 线段树 or 树状数组 复杂度计算】Auxiliary Set 一个点如果是好点或是两个好点的LCA就是好

Auxiliary Set Time Limit: 9000/4500 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) ...

对AOV(DAG的一种,Activity on vertex)拓扑排序得到chain(人为添加边构成全序)来判断AOV是否有环

等价关系: 如果集合上的关系是 自反的,对称的(a~b=>b~a)和传递的,则称 为R是集合上的偏序关系。 偏序关系: 如果集合上的关系是 自反的(a a=b)和传递的(a 合, 全序关系: 如果集合...
  • sinapme
  • sinapme
  • 2013年09月25日 17:25
  • 684

【2015-2016 ACM-ICPC, NEERC, Northern Subregional Contest G】【脑洞 拓扑排序 大根堆小根堆极限维护】Graph DAG加k边使得最小拓扑序最大

#include #include #include #include #include #include #include #include #include #include #include ...

hdu 3342 Legal or Not(DAG的拓扑排序)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3342 题意:给出一个有向无环图,问是否存在拓扑序列。 解题方案:用入度表的方法,即每次找入度为0的点,...
  • mr_zj_
  • mr_zj_
  • 2017年04月28日 18:08
  • 766

用拓扑排序算法分析学习计划

  • 2011年12月24日 08:37
  • 4KB
  • 下载

FOJ有奖月赛-2015年11月 Problem F 攻占计划

Problem F 攻占计划 Accept: 113    Submit: 232 Time Limit: 1000 mSec    Memory Limit : 131072 KB ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:【FOJ2210 11月月赛F】【DFS or 拓扑排序】攻占计划 n个点m条边DAG破坏一个点使得不可达点数尽可能多
举报原因:
原因补充:

(最多只允许输入30个字)