标签:
1 //It is made by jump~ 2 #include <iostream> 3 #include <cstdlib> 4 #include <cstring> 5 #include <cstdio> 6 #include <cmath> 7 #include <algorithm> 8 #include <ctime> 9 #include <vector> 10 #include <queue> 11 #include <map> 12 #include <set> 13 #ifdef WIN32 14 #define OT "%I64d" 15 #else 16 #define OT "%lld" 17 #endif 18 using namespace std; 19 typedef long long LL; 20 const int MAXN = 3011; 21 const int MAXM = 20011; 22 const double eps = 0.000000001; 23 int n,m,ecnt; 24 int first[MAXN],u[MAXM],v[MAXM]; 25 double w[MAXM],dis[MAXN]; 26 double l,r,mid,ans; 27 bool ok; 28 bool vis[MAXN]; 29 struct edge{ 30 int next,to; 31 double w; 32 }e[MAXM]; 33 34 inline int getint() 35 { 36 int w=0,q=0; 37 char c=getchar(); 38 while((c<‘0‘ || c>‘9‘) && c!=‘-‘) c=getchar(); 39 if (c==‘-‘) q=1, c=getchar(); 40 while (c>=‘0‘ && c<=‘9‘) w=w*10+c-‘0‘, c=getchar(); 41 return q ? -w : w; 42 } 43 44 inline void link(int x,int y,double z){ e[++ecnt].next=first[x]; first[x]=ecnt; e[ecnt].to=y; e[ecnt].w=z; } 45 46 inline void SPFA(int x){//DFS版SPFA找负权环,只有碰到负边才走 47 vis[x]=1; 48 for(int i=first[x];i;i=e[i].next){ 49 int v=e[i].to; 50 if(dis[v]>dis[x]+e[i].w) { 51 if(vis[v]) { ok=true; return ; } 52 dis[v]=dis[x]+e[i].w; SPFA(v); 53 if(ok) return ; 54 } 55 } 56 vis[x]=0;//退出时记得清空标记 57 } 58 59 inline bool check(double val){ 60 memset(first,0,sizeof(first)); ecnt=0; 61 memset(vis,0,sizeof(vis)); 62 memset(dis,0,sizeof(dis)); 63 ok=false; for(int i=1;i<=m;i++) link(u[i],v[i],w[i]-val); 64 for(int i=1;i<=n;i++) { 65 SPFA(i);//DFS版SPFA 66 if(ok) return true; 67 } 68 return false; 69 } 70 71 inline void work(){ 72 n=getint(); m=getint(); 73 for(int i=1;i<=m;i++) u[i]=getint(),v[i]=getint(),scanf("%lf",&w[i]); 74 75 l=-10000000; r=10000000; 76 while(r-l>eps) { 77 mid=(l+r)/2.0; 78 if(check(mid)) ans=mid,r=mid;//已经产生负权环 79 else l=mid; 80 } 81 printf("%.8lf",ans); 82 } 83 84 int main() 85 { 86 work(); 87 return 0; 88 }
标签:
原文地址:http://www.cnblogs.com/ljh2000-jump/p/5758362.html