【FOJ2210 11月月赛F】【DFS or 拓扑排序】攻占计划 n个点m条边DAG破坏一个点使得不可达点数尽可能多
来源:互联网 发布:uu黑历史知乎 编辑:程序博客网 时间:2024/05/01 02:06
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|1typedef 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 41 32 33 43 510 81 32 33 43 56 77 88 99 10*/
1 0
- 【FOJ2210 11月月赛F】【DFS or 拓扑排序】攻占计划 n个点m条边DAG破坏一个点使得不可达点数尽可能多
- 【codeforces 721C】【DAG 按照拓扑排序记忆化DFS】C. Journey 【DAG图,5000个点,5000条边 让你求从1到n的路径长度不超过T中经过点数最多的一条 】
- 树型DP ZOJ3527 8月月赛1008 一图N个点,N条边,取某个点会有信任点,同时某个点与它的后继结点同时取的话,它的信任点会改变一个值,问怎么取点,使得总信任点最大
- 给你一个 n 个点,m 条边的无向图,求至少要在这个的基础上加多少条无向边使得任意两个点可达~
- 【HDU5638 BestCoder Round 74 (div1)C】【贪心 线段树or树套树or队列】Toposort n点m边删k边使得拓扑序最小
- 求一条直线经过一个直角坐标系里m个点最多点的点数
- Codeforces Round #375 (Div. 2) E. One-Way Reform(有n个点,m条无向边,给每条边定向,使得入度等于出度的点最多)
- n个点m条边构成的简单无相连通图个数
- 【Codeforces Round 364 (Div 2)F】【暴力 双连通分量求桥】Break Up n点m边最多割2边最小成本使得S与T不联通
- Codeforces Round #375 (Div. 2) F. st-Spanning Tree(给你n个点,m条边,有两个给定的点S,T以及它们在生成树中最大的度数)
- m个点取n个点计算
- 平面上有2N+1个点,如何画一个圆,使得N个点在圆内,N个点在圆外,一个点在圆上
- 【FOJ2207 11月月赛C】【DFS栈性质应用 离线处理】以撒的结合 从x到y路径上的第k个点 询问众多
- POJ 3114 - Countries in War(强连通分量+缩点+拓扑排序+DAG最短路)
- BZOJ 1093 浅谈tarjan缩点DAG最长路径即拓扑排序
- FOJ有奖月赛-2015年11月-Problem F 攻占计划
- FOJ有奖月赛-2015年11月 Problem F 攻占计划
- FOJ有奖月赛-2015年11月 Problem F 攻占计划
- 教你改变Linux字体和背景颜色
- 八个Docker的真实应用场景
- Windows10 64位 matlab&VC混合编程
- hibernate中部分函数学习
- 没有走过的路
- 【FOJ2210 11月月赛F】【DFS or 拓扑排序】攻占计划 n个点m条边DAG破坏一个点使得不可达点数尽可能多
- 应用抽象工厂模式自己动手写一个ioc
- 20151118 parameter
- UVa 1599 Ideal Path
- 解决在onCreate()过程中获取View的width和Height为0的4种方法
- NodeJs 安全
- 数据库 select @@identity说明
- Python中指针式传递的函数遇到的问题
- Android性能测试之概述(一)