poj 1364 King 差分约束

   一道较简单的差分约束题,但这题我忽略了两个问题,以致wrong了13次啊大哭。。首先要注意的是,此题中|V|=n+1,所以外层循环的循环次数为n,而不是想当然的认为是n-1;第二点就是本题中的约束条件不是大于就是小于,不包含等于,所以不能直接按照已知条件建边。

   发现这两个错误后,总算A掉了啊啊……

/*
此题是一道差分约束问题,但有个细节需要注意下,就是
此处的约束条件是'<'或'>',不包含'=’,所以不能直接根据题意建边,
注意到集合S中的元素为整数,所以可以对原始约束条件做一个处理,
比如,已知s3-s0>1,我们可以写成s3-s0>=2,这样该题就完全成为了一个
差分约束了。
*/
#include<iostream>
#include<cstdio>

using namespace std;
struct
{
    int u,v,w;
}e[105];
int  d[105];
int n,m;

bool relax(int u,int v,int w)
{
    if(d[u]+w<d[v])
    {
        d[v]=d[u]+w;
        return true;
    }
    return false;
}

bool Bellman_Ford()
{
    int i,j;
    for(i=1;i<=n;i++)
        d[i]=100000000;
    d[0]=0;
    for(i=0;i<n;i++)//注意顶点数|V|=n+1
        for(j=0;j<m;j++)
            relax(e[j].u,e[j].v,e[j].w);
    for(i=0;i<m;i++)
        if(relax(e[i].u,e[i].v,e[i].w))
            return false;
    return true;
}

int main()
{
    int a,b,c;
    char op[3];
    while(scanf("%d",&n),n)
    {
        scanf("%d",&m);
        for(int i=0;i<m;i++)
        {
            scanf("%d%d%s%d",&a,&b,op,&c);
            b+=a;
            if(op[0]=='g')//">"
            {
                e[i].u=b;
                e[i].v=a-1;
                e[i].w=-c-1;
            }
            else//"<"
            {
               e[i].u=a-1;
               e[i].v=b;
               e[i].w=c-1;
            }
        }
        if(Bellman_Ford())
            printf("lamentable kingdom\n");
        else
            printf("successful conspiracy\n");
    }
    return 0;
}


 

你可能感兴趣的:(poj 1364 King 差分约束)