2833 奇怪的梦境
来源:互联网 发布:三端口环形器端口1.2.3 编辑:程序博客网 时间:2024/05/04 06:56
2833 奇怪的梦境
时间限制: 1 s
空间限制: 128000 KB
题目等级 : 黄金 Gold
题目描述 Description
Aiden陷入了一个奇怪的梦境:他被困在一个小房子中,墙上有很多按钮,还有一个屏幕,上面显示了一些信息。屏幕上说,要将所有按钮都按下才能出去,而又给出了一些信息,说明了某个按钮只能在另一个按钮按下之后才能按下,而没有被提及的按钮则可以在任何时候按下。可是Aiden发现屏幕上所给信息似乎有矛盾,请你来帮忙判断。题目描述 Description
Aiden陷入了一个奇怪的梦境:他被困在一个小房子中,墙上有很多按钮,还有一个屏幕,上面显示了一些信息。屏幕上说,要将所有按钮都按下才能出去,而又给出了一些信息,说明了某个按钮只能在另一个按钮按下之后才能按下,而没有被提及的按钮则可以在任何时候按下。可是Aiden发现屏幕上所给信息似乎有矛盾,请你来帮忙判断。输入描述 Input Description
第一行,两个数N,M,表示有编号为1…N这N个按钮,屏幕上有M条信息。
接下来的M行,每行两个数ai,bi,表示bi按钮要在ai之后按下。所给信息可能有重复,保证ai≠bi。输出描述 Output Description
若按钮能全部按下,则输出“o(∩_∩)o”。
若不能,第一行输出“T_T”,第二行输出因信息有矛盾而无法确认按下顺序的按钮的个数。输出不包括引号。样例输入 Sample Input
3 3
1 2
2 3
3 2样例输出 Sample Output
T_T
2数据范围及提示 Data Size & Hint
对于30%的数据,保证0<N≤100。
对于50%的数据,保证0<N≤2000。
对于70%的数据,保证0<N≤5000。
对于100%的数据,保证0<N≤10000,0
/*作者:MZ_OIer题目:p2833 奇怪的梦境*/#include<cstdio>#include<queue>#include <cstring>using namespace std;queue<int>q;int n,m;int k=1;int head[10005];int in[10005];struct NODE{ int end,next;}node[25005];void add(int x,int y){//x出发点 y结束点 node[k].end=y; node[k].next=head[x]; head[x]=k++; in[y]++;}void read(){ memset(head,-1,sizeof(head)); scanf("%d%d",&n,&m); int a,b; for(int i=1;i<=m;i++){ scanf("%d%d",&a,&b); add(a,b); }}void topology(){ for(int i=1;i<=n;i++){ if(in[i]==0) q.push(i); } int x; int cnt=0; while(!q.empty()){ x=q.front(); q.pop(); cnt++; int ed; for(int i=head[x];i!=-1;i=node[i].next){ ed=node[i].end; in[ed]--; if(in[ed]==0)q.push(ed); } } if(cnt==n)printf("o(∩_∩)o"); else{ printf("T_T\n"); int ans=n-cnt; printf("%d\n",ans); }}int main(){ read(); topology(); return 0;}
- 2833 奇怪的梦境
- 2833 奇怪的梦境
- 2833 奇怪的梦境
- CodeVs 2833 奇怪的梦境
- 【CODEVS】2833 奇怪的梦境
- Codevs 2833 奇怪的梦境
- 【codevs 2833】奇怪的梦境
- 【codevs 2833】奇怪的梦境
- Codevs 2833 奇怪的梦境
- 2833 奇怪的梦境 【解题报告】
- codevs 2833 奇怪的梦境 题解报告
- codevs 2833 奇怪的梦境 拓扑排序
- [codevs2833] 奇怪的梦境
- 奇怪的梦境
- codevs 2833 奇怪的梦境(拓扑排序)
- codevs 2833 奇怪的梦境(拓扑排序)
- codevs2833 2833 奇怪的梦境(拓扑排序)
- 【CS 2833】奇怪的梦境(拓扑排序top_sort)
- 第九周项目5-方程也是类
- 第11周 自选阅读1
- 黑马程序员--IOS入学学习--7-面向对象的三大特性
- 嵌入式学习笔记103-uboot_1.1.6移植(3)
- 《别做正常的傻瓜》读书笔记
- 2833 奇怪的梦境
- 每日一译2015-05-17
- 【HDU】 1160 FatMouse's Speed (DP)
- 消除浮动》》页面局部布局详解
- javax.servlet.AsyncContext
- Windows和linux下 OpenVPN 记住用户名和密码、自动连接的方法
- [Leetcode 207, Medium] Course Schedule
- 各种字符编码方式详解及由来(ANSI,UNICODE,UTF-8,GB2312,GBK)
- poj 1422 最小路径覆盖