BZOJ3436 小K的农场
3436: 小K的农场
Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1761 Solved: 785
[Submit][Status][Discuss]
Description
背景
小K是个特么喜欢玩MC的孩纸。。。
描述
小K在MC里面建立很多很多的农场,总共n个,以至于他自己都忘记了每个农场中种植作物的具体数量了,他只记得
一些含糊的信息(共m个),以下列三种形式描述:农场a比农场b至少多种植了c个单位的作物,农场a比农场b至多
多种植了c个单位的作物,农场a与农场b种植的作物数一样多。但是,由于小K的记忆有些偏差,所以他想要知道存
不存在一种情况,使得农场的种植作物数量与他记忆中的所有信息吻合。
Input
第一行包括两个整数n和m,分别表示农场数目和小K记忆中的信息的数目接下来m行:如果每行的第一个数是1,接
下来有三个整数a,b,c,表示农场a比农场b至少多种植了c个单位的作物如果每行第一个数是2,接下来有三个整数a
,b,c,表示农场a比农场b至多多种植了c个单位的作物如果每行第一个数是3,接下来有两个整数a,b,表示农场a
种植的数量与b一样。1<=n,m,a,b,c<=10000
Output
如果存在某种情况与小K的记忆吻合,输出”Yes”,否则输出”No”
Sample Input
3 3
3 1 2
1 1 3 1
2 2 3 2
3 1 2
1 1 3 1
2 2 3 2
Sample Output
Yes
样例解释
三个农场种植的数量可以为(2,2,1)
样例解释
三个农场种植的数量可以为(2,2,1)
HINT
Source
用bellmen_ford进行判环
废话不说了
直接上代码
#include <bits/stdc++.h>
#define ll long long
#define inf 100000010
using namespace std;
inline int read(){
int x=0;int f=1;char ch=getchar();
while(!isdigit(ch)) {if(ch=='-') f=-1;ch=getchar();}
while(isdigit(ch)) {x=x*10+ch-'0';ch=getchar();}
return x*f;
}
const int MAXN=1e6+10;
namespace zhangenming{
struct node{
int x,y,v;
}e[MAXN];
int dis[MAXN],len,n,m;
inline void insert(int xx,int yy,int vv){
e[++len].x=xx;
e[len].y=yy;
e[len].v=vv;
}
int bellman_ford(){
int flag;memset(dis,10,sizeof(dis));
for(int i=1;i<n;i++){
flag=1;
for(int j=1;j<=len;j++){
if(dis[e[j].y]>dis[e[j].x]+e[j].v){
dis[e[j].y]=dis[e[j].x]+e[j].v;flag=0;
}
}
if(flag) break;
}
for(int j=1;j<=len;j++){
if(dis[e[j].y]>dis[e[j].x]+e[j].v) return 0;
}
return 1;
}
void init(){
n=read();m=read();
while(m--){
int x=read();
if(x==3){
int xx=read();int yy=read();
insert(xx,yy,0);insert(yy,xx,0);
}
if(x==1){
int xx=read();int yy=read();int vv=read();
insert(xx,yy,-vv);
}
if(x==2){
int xx=read();int yy=read();int vv=read();
insert(xx,yy,vv);
}
}
}
}
int main(){
using namespace zhangenming;
init();
if(bellman_ford()) cout<<"Yes"<<endl;
else cout<<"No"<<endl;
return 0;
}

浙公网安备 33010602011771号