poj 3259 Wormholes

来源:互联网 发布:java attribute用法 编辑:程序博客网 时间:2024/05/01 08:53

求负权回路,通过这个题也理解了负权回路,以前也用过floyd算法算最短路径,看来也可以算负权回路。

题意:路径可以来回走,虫洞单向的,虫洞可以回到之前的时间,这样的事件不超过1s就可以了

#include<cstdio>#include<cstring>#include<algorithm>#include<iostream>using namespace std;int map[505][505],n,m,k;int floyd(){    int i,j,k,f=0;    for(k=1;k<=n;k++)        for(i=1;i<=n;i++){        for(j=1;j<=n;j++)    {        int t=map[i][k]+map[k][j];        if(map[i][j]>t)map[i][j]=t;    }    if(map[i][i]<0)return 1;}    return f;}int main(){    int t;    scanf("%d",&t);    while(t--)    {        int i,a,b,c;        scanf("%d%d%d",&n,&m,&k);        memset(map,0x3f3f3f3f,sizeof(map));        for(i=1;i<=n;i++)map[i][i]=0;        for(i=1;i<=m;i++)        {            scanf("%d%d%d",&a,&b,&c);            if(c<map[a][b])map[a][b]=map[b][a]=c;        }        for(i=1;i<=k;i++)        {            scanf("%d%d%d",&a,&b,&c);            map[a][b]=-c;        }        int f=floyd();        if(!f)printf("NO\n");            else printf("YES\n");    }    return 0;}


0 0
原创粉丝点击