poj 1364 King 差分约束

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

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

【poj 1364 King 差分约束】

    推荐阅读