标签:联通
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#define N 310
#define M 1010
#define INF 0x7f7f7f7f
using namespace std;
double a[M][M<<2];
int st[N];
struct line
{
int u,v,w,ff,a,b;
}l[M];
int head[N],cnt,n,m,top,tot;
struct node
{
int from,to,ff,no,a,b,next;
}edge[M<<1];
void init()
{
memset(head,-1,sizeof(head));cnt=1;
}
void edgeadd(int from,int to,int ff,int no)
{
edge[cnt].from=from,edge[cnt].to=to,edge[cnt].ff=ff,edge[cnt].no=no;
edge[cnt].next=head[from];
head[from]=cnt++;
}
void dfs(int now,int fa,int e,int edge0)
{
if(now==e)
{
while(top)
{
tot++;
int no=st[top--];
a[no][tot]=1;
a[edge0][tot]=1;
a[0][tot]=l[no].w-l[edge0].w;
}
return;
}
for(int i=head[now];i!=-1;i=edge[i].next)
{
int to=edge[i].to;
if(to==fa)continue;
st[++top]=edge[i].no;
dfs(to,now,e,edge0);
st[top--]=0;
}
}
int check()
{
for(int i=1;i<=tot;i++)
if(a[0][i]>0)return i;
return 0;
}
void Simplex()
{
while(int t=check())
{
double limit=INF;
int choseline;
for(int i=1;i<=m;i++)
{
if(a[i][t]<=0)continue;
else if(a[i][0]/a[i][t]<limit)limit=a[i][0]/a[i][t],choseline=i;
}
if(limit==INF){a[0][0]=INF;break;}
double di=a[choseline][t];
for(int i=0;i<=tot;i++)
{
if(i==t)a[choseline][i]/=di;
a[choseline][i]/=di;
}
for(int i=0;i<=m;i++)
{
if(i==choseline||a[i][t]==0)continue;
if(i==0)a[i][0]+=a[i][t]*a[choseline][0];
else a[i][0]-=a[i][t]*a[choseline][0];
double l=a[i][t];
for(int j=1;j<=tot;j++)
{
if(j==t)a[i][j]=-l*a[choseline][j];
else a[i][j]-=l*a[choseline][j];
}
}
}
}
int main()
{
init();
scanf("%d%d",&n,&m);
for(int i=1;i<=m;i++)
{
int u,v,w,ff,A,b,no;
scanf("%d%d%d%d%d%d",&u,&v,&w,&ff,&A,&b);
l[i].u=u,l[i].v=v,l[i].w=w,l[i].ff=ff,l[i].a=A,l[i].b=b;
if(ff)a[i][0]=b;
else a[i][0]=A;
if(ff)edgeadd(u,v,ff,i),edgeadd(v,u,ff,i);
}
for(int i=1;i<=m;i++)
{
if(l[i].ff==0)
{
top=0;
dfs(l[i].u,0,l[i].v,i);
}
}
Simplex();
printf("%.0lf\n",a[0][0]);
}
版权声明:本文为博主原创文章,未经博主允许不得转载。
标签:联通
原文地址:http://blog.csdn.net/wzq_qwq/article/details/47838789