zoukankan      html  css  js  c++  java
  • POJ 1285 确定比赛名次

    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
     Author
    SmallBeer(CML)
     Source
    #include<iostream>
    #include<cstdio>
    #include<cstring>
    using namespace std;
    int map[510][510]={0};
    int f[510]={0};
    int main()
    {
        
        
        memset(map,0,sizeof(map));
        memset(f,0,sizeof(f));
        int n,m,ai,bi;
        scanf("%d%d",&n,&m);
        for(int i=1;i<=m;i++)
        {
            cin>>ai>>bi;
            f[bi]++;
            map[ai][bi]=1;
        }
        for(int i=1;i<=n;i++)
        {
            int t=0;
            for(int j=1;j<=n;j++)
            {
             
             if(f[j]==0)
             {
                 f[j]--;
                 if(i!=n) printf("%d ",j);
                 else printf("%d
    ",j);
                 for(int k=1;k<=n;k++)
                 {
                     if(map[j][k])
                      f[k]--;
                 }
                 break; 
             }
             
            } 
        }
            
    
        
        return 0;
    } 

    拓扑排序~~~

  • 相关阅读:
    结队完成-连续最大子数组和
    一、数据库的基础简介
    十六、Shell之expect自动化交互程
    十五、Shell之数组
    十四、循环控制
    十三、Shell之select语句
    Linux系统产生随机数的6种方法
    十二、Shell之for循环
    十一、Shell之while&&until循环
    Shell补充之后台执行脚本程序
  • 原文地址:https://www.cnblogs.com/suishiguang/p/5876929.html
Copyright © 2011-2022 走看看