SDUT 3304 拓扑排序(链表)

选课大作战

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,MN表示课程总数量,课程编号为1..NM表示顺序关系的数量。1 <= N <= 100,000. 1 <= M <= 500,000
2..M+1行:每行2个整数,A,B。表示课程A是课程B的前置课程。

输出

 第 1..T 行:每行 1 个字符串,若该组信息无误,输出 "Correct" ,若该组信息有误,输出 "Wrong"

示例输入

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();

        }
    }
}
 

你可能感兴趣的:(SDUT 3304 拓扑排序(链表))