zoukankan      html  css  js  c++  java
  • HDU 1285 确定比赛名次(toposort)

    确定比赛名次




    Problem Description
    有 N个比赛队(1<=N<=500),编号依次为1,2,3,。。。。,N进行比赛,比赛结束后,裁判委员会要将所有参赛队伍从前往后依次排 名,但现在裁判委员会不能直接获得每个队的比赛成绩,只知道每场比赛的结果,即P1赢P2,用P1,P2表示,排名时P1在P2之前。现在请你编程序确定 排名。
     
    Input
    输入有若干组,每组中的第一行为二个数N(1<=N<=500),M;其中N表示队伍的个数,M表示接着有M行的输入数据。接下来的M行数据中,每行也有两个整数P1,P2表示即P1队赢了P2队。
     
    Output
    给出一个符合要求的排名。输出时队伍号之间有空格,最后一名后面没有空格。

    其他说明:符合条件的排名可能不是唯一的,此时要求输出时编号小的队伍在前;输入数据保证是正确的,即输入数据确保一定能有一个符合要求的排名。
     
    Sample Input
    4 3
    1 2
    2 3
    4 3
     
    Sample Output
    1 2 4 3
     1 #include<cstdio>
     2 #include<cstring>
     3 #include<vector>
     4 #include<queue>
     5 #include<algorithm>
     6 using namespace std;
     7 
     8 int G[505][505];
     9 int indegree[505];
    10 int topo[505];
    11 int t,n,m;
    12 void toposort()
    13 {
    14     t=0;
    15     priority_queue<int,vector<int>,greater<int> >q;
    16     for(int i=1;i<=n;i++)
    17     {
    18         if(indegree[i]==0)
    19         q.push(i);
    20     }
    21     int temp;
    22     while(!q.empty())
    23     {
    24         temp=q.top();
    25         topo[t++]=temp;
    26         q.pop();
    27         for(int i=1;i<=n;i++)
    28         {
    29             if(G[temp][i])
    30             {
    31                 indegree[i]--;
    32                 if(indegree[i]==0)
    33                 q.push(i);
    34             }
    35         }
    36     }
    37 }
    38 
    39 
    40 int main()
    41 {
    42     //freopen("in.txt","r",stdin);
    43     int i,a,b;
    44     while(scanf("%d%d",&n,&m)!=EOF)
    45     {
    46         memset(indegree,0,sizeof(indegree));
    47         memset(G,0,sizeof(G));
    48         for(i=0;i<m;i++)
    49         {
    50             scanf("%d%d",&a,&b);
    51             if(!G[a][b])
    52             indegree[b]++;
    53             G[a][b]=1;
    54         }
    55         toposort();
    56         for(i=0;i<n-1;i++)
    57         printf("%d ",topo[i]);
    58         printf("%d
    ",topo[i]);
    59     }
    60     return 0;
    61 }
  • 相关阅读:
    Go语言基础练习题系列2
    Go语言基础练习题系列1
    Go语言基础之8--面向对象编程1之结构体(struct)
    Go语言基础之7--函数详解
    分数规划(Bzoj1486: [HNOI2009]最小圈)
    [APIO2018] Circle selection 选圆圈(假题解)
    Bzoj4520: [Cqoi2016]K远点对
    KDTree(Bzoj2648: SJY摆棋子)
    矩阵树定理
    CF235C Cyclical Quest
  • 原文地址:https://www.cnblogs.com/homura/p/4727536.html
Copyright © 2011-2022 走看看