标签:
眼看着大一新生就要来了,原大一的成了学叔学婶。
小C又在为了新学期的选课问题忙了起来。。。。。渐渐地他发现了一个问题:当他想学“计算机网络”这门课时,选课系统告诉他必须学过“离散数学”才能学这门科目。
所以我们就称“离散数学”是“计算机网络”的必学科目。现在已知选课系统收集了很多科目的顺序关系,但是,这个选课系统出了一些故障,一些信息可能不准确,所以请你来帮小C判断一下信息是否错误,首先信息错误是指“科目X是科目Y的必学科目,同时科目Y也是科目X的必学科目”,"科目X是科目Y的必学科目,科目Y是科目Z的必学科目,科目Z是科目X的必学科目"这类也是错误的。
接下来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的前置课程。
2 2 2 1 2 2 1 3 2 1 2 1 3
Wrong Correct
#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();
}
}
}
版权声明:本文为博主原创文章,未经博主允许不得转载。
标签:
原文地址:http://blog.csdn.net/became_a_wolf/article/details/48084705