ZOJ 2770 Burn the Linked Camp(spfa&&bellman)

//差分约束  >=求最长路径 <=求最短路径   结果都一样
//spfa
#include<stdio.h> #include<string.h> #include<limits.h> #include<queue> using namespace std; #define N 1010 #define M 1010*1010//注意边和点集的数组大小 struct edge { int to,value,next; }; struct edge edges[M]; int heads[N],len=0; int dis[N]; int addedge(int u,int v,int w) { edges[len].to=v,edges[len].value=w,edges[len].next=heads[u]; heads[u]=len++; return 0; } int n,m; int spfa(int v) { queue<int> q; int inqueue[N]; memset(inqueue,0,sizeof(inqueue)),inqueue[v]=1; q.push(v); for(int i=0;i<=n;i++) dis[i]=INT_MIN; dis[v]=0; int times[N]; memset(times,0,sizeof(times)),times[v]=1; int temp=0; while(!q.empty()){ int x=q.front(); q.pop(); inqueue[x]=0; for(int i=heads[x];i!=-1;i=edges[i].next){ int to=edges[i].to,value=edges[i].value; if(value+dis[x]>dis[to]){ dis[to]=value+dis[x]; if(!inqueue[to]){ //注意已经在队列里面的不用再加入队列 inqueue[to]=1,q.push(to); times[to]++; if(times[x]>n){ return -1;//返回值有可能是0 不能将0作为区别的标记 } } } } } return dis[n]; } int main(void) { int i,num; while(scanf("%d%d",&n,&m)!=EOF){ len=0; memset(heads,-1,sizeof(heads)); for(i=1;i<=n;i++){ scanf("%d",&num); addedge(i,i-1,-num); addedge(0,i,0); } for(i=1;i<=m;i++){ int u,v,w; scanf("%d%d%d",&u,&v,&w); addedge(u-1,v,w); } int h=spfa(0); if(h!=-1) printf("%d\n",h); else printf("Bad Estimations\n"); } return 0; }
//bellman
#include <iostream>
#include <stdio.h>
#include <string.h>

using namespace std;
#define INF 2000000000
int u[12005],v[12005],w[12005],n,m,total,d[1005];
void Edge(int s,int e,int val){
	u[total]=s;
	v[total]=e;
	w[total++]=val;
}
int Bellman(){
	int i,e;
	for(i=1;i<=n;i++) d[i]=-INF;
	d[0]=0;
	for(i=1;i<=n;i++){
		for(e=0;e<total;e++){
			if(d[v[e]]<d[u[e]]+w[e])	
				d[v[e]]=d[u[e]]+w[e];
		}
	}
	int ans=d[n];
	for(e=0;e<total;e++)
		if(d[v[e]]<d[u[e]]+w[e]) ans=-1;
	return ans;
}
int main(){
	int a,b,c,cnt,i;
	while(scanf("%d%d",&n,&m)!=EOF){
		total=0;
		for(i=1;i<=n;i++){
			scanf("%d",&c);
			Edge(0,i,0);
			Edge(i,i-1,-c);
		}
		for(i=0;i<m;i++){
			scanf("%d%d%d",&a,&b,&c);
			Edge(a-1,b,c);
		}
		
		cnt=Bellman();
		for(i=0;i<n;i++) printf("%d ",d[i]);
		puts("");
		if(cnt==-1) cout<<"Bad Estimations\n";
		else cout<<cnt<<"\n";
	}
	return 0;
}

  

 
posted @ 2014-07-21 19:06  keyboard3  阅读(147)  评论(0编辑  收藏  举报