一道较简单的差分约束题,但这题我忽略了两个问题,以致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;
}