SDUT 3304 拓扑排序(链表)
来源:互联网 发布:东莞广电网络 编辑:程序博客网 时间:2024/05/16 01:45
选课大作战
Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^
题目描述
眼看着大一新生就要来了,原大一的成了学叔学婶。
小C又在为了新学期的选课问题忙了起来。。。。。渐渐地他发现了一个问题:当他想学“计算机网络”这门课时,选课系统告诉他必须学过“离散数学”才能学这门科目。
所以我们就称“离散数学”是“计算机网络”的必学科目。现在已知选课系统收集了很多科目的顺序关系,但是,这个选课系统出了一些故障,一些信息可能不准确,所以请你来帮小C判断一下信息是否错误,首先信息错误是指“科目X是科目Y的必学科目,同时科目Y也是科目X的必学科目”,"科目X是科目Y的必学科目,科目Y是科目Z的必学科目,科目Z是科目X的必学科目"这类也是错误的。
输入
第1行:1个整数T,表示数据的组数T(1 <= T <= 5)
接下来T组数据按照以下格式:
第1行:2个整数,N,M。N表示课程总数量,课程编号为1..N。M表示顺序关系的数量。1 <= N <= 100,000. 1 <= M <= 500,000
第2..M+1行:每行2个整数,A,B。表示课程A是课程B的前置课程。
输出
第1..T行:每行1个字符串,若该组信息无误,输出"Correct",若该组信息有误,输出"Wrong"。
示例输入
22 21 22 13 21 21 3
示例输出
WrongCorrect
提示
提示
来源
#include <iostream>#include<cstdio>#include<cstring>#include<algorithm>#include<cmath>using namespace std;int T,n,m;struct node{ int to; node *next;}*temp;node *List[100010];int du[100010];int Topsort(){ int i,top=-1; int flag=0; int pos=0; for(int i=0;i<n;i++) { if(du[i]==0) { du[i]=top; top=i; } } for(int i=0;i<n;i++) { if(top==-1) { flag=1; break; } else { int j=top; top=du[top]; temp=List[j]; while(temp) { int k=temp->to; if(--du[k]==0) { du[k]=top; top=k; } temp=temp->next; } } } if(flag) printf("Wrong\n"); else printf("Correct\n");}int main(){ while(~scanf("%d",&T)) { while(T--) { memset(List,0,sizeof(List)); memset(du,0,sizeof(du)); scanf("%d%d",&n,&m); for(int i=0; i<m; i++) { int u,v; scanf("%d%d",&u,&v); u--,v--; du[v]++; temp=new node; temp->to=v; temp->next=NULL; if(List[u]==NULL) List[u]=temp; else { temp->next=List[u]; List[u]=temp; } } Topsort(); } }}
0 0
- SDUT 3304 拓扑排序(链表)
- SDUT 2140-拓扑排序
- [SDUT](2140)图结构练习——判断给定图是否存在合法拓扑序列 ---拓扑排序(图)
- 拓扑排序
- 拓扑排序
- 拓扑排序
- 拓扑排序
- 拓扑排序
- 拓扑排序
- 拓扑排序
- 拓扑排序
- 拓扑排序
- 拓扑排序
- 拓扑排序
- 拓扑排序
- 拓扑排序
- 【拓扑排序】
- 拓扑排序
- Linux下出现 error: mysql.h: No such file or directory 的解决办法
- 为什么面试总喜欢考算法题?
- 使用VS2010创建WebService 发布、测试
- 霓歌即时通讯中的相关专利整理(九)
- html5中canvas 错误集锦1(8.28)
- SDUT 3304 拓扑排序(链表)
- Java 中正确使用 wait, notify 和 notifyAll – 以生产者消费者模型为例
- 【乱搞】【HNOI 2008】【bzoj 1011】遥远的行星
- java Hello world
- 跳表(Skip List)的介绍以及查找插入删除等操作
- Docker新手安装笔记
- Linux的inode的理解
- Qt 简介
- eclipse下软件测试合集,findbugs,PMD,Sourcemonitor,Junit的安装和使用详细图文