poj 1364 King 差分约束

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

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

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

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"
            {
                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;
}


 

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