zoukankan      html  css  js  c++  java
  • POJ3660 传递闭包———floyd算法

    POJ3660 Cow Contest

    题目链接:http://poj.org/problem?id=3660

    题意:农名约翰有些奶牛,约翰通过让他们决斗来决定他们的排名,约翰让这些奶牛一对一打完一定的局数之后,问有哪些奶牛的排名是可以确定的(注:a打得过b,b打得过c,则a打得c)

    根据题意我们明白当一个奶牛和其他的所有奶牛都存在胜负关系的时候,他的排名就是确定的。

    思路:利用floyd算法,传递闭包,算出可达矩阵。然后在每一行去查询该点和其他所有的点的联系是不是n-1。

    代码:

    //Author: xiaowuga
    #include<iostream>
    #include<cstring>
    #include<vector>
    #include<queue>
    #define maxx INT_MAX
    #define minn INT_MIN
    #define inf 0x3f3f3f3f
    const long long N=110; 
    using namespace std;
    typedef long long LL;
    int n,m;
    int p[N][N]={0};
    void floyd(){
        for(int k=1;k<=n;k++)
            for(int i=1;i<=n;i++)
               for(int j=1;j<=n;j++)
                  p[i][j]=p[i][j]||p[i][k]&&p[k][j]; 
    }
    int main(){
        cin>>n>>m;
        for(int i=0;i<m;i++){
            int a,b;
            cin>>a>>b;
            p[a][b]=1;
        }
        floyd();
        int ct=0;
        for(int i=1;i<=n;i++){
            int c=0;
            for(int j=1;j<=n;j++){
                if(i==j) continue;
                if(p[i][j]||p[j][i]) c++;
            }
            if(c==n-1) ct++;
        }
        cout<<ct<<endl;
        return 0;
    }
  • 相关阅读:
    11.分类与监督学习,朴素贝叶斯分类算法
    14 深度学习-卷积
    13-垃圾邮件分类2
    12.朴素贝叶斯-垃圾邮件分类
    9、主成分分析
    8、特征选择
    7.逻辑回归实践
    6.逻辑归回
    5.线性回归算法
    15 手写数字识别-小数据集
  • 原文地址:https://www.cnblogs.com/xiaowuga/p/7226540.html
Copyright © 2011-2022 走看看