国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 學(xué)院 > 開(kāi)發(fā)設(shè)計(jì) > 正文

BZOJ 1070, 修車(chē)

2019-11-10 21:31:39
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

PRoblem

傳送門(mén)

Mean

某汽車(chē)維修中心有m位技術(shù)人員,有n輛汽車(chē)待修理。 不同的技術(shù)人員修理不同車(chē)輛耗時(shí)不同。 最小化平均等待時(shí)間。

Analysis

經(jīng)典的最小費(fèi)用最大流。 設(shè)第j位技術(shù)人員修理第i輛汽車(chē)耗時(shí)為w[i,j] 。 將技術(shù)人員拆成n個(gè)點(diǎn),每個(gè)點(diǎn)向汽車(chē)連容量為1的邊,第k個(gè)點(diǎn)所連邊費(fèi)用為k×w[i,j],表示倒數(shù)第k個(gè)修理該車(chē)則對(duì)總等待時(shí)間貢獻(xiàn)k×w[i,j]。 再由源點(diǎn)想技術(shù)人員,汽車(chē)向匯點(diǎn)分別連容量為1, 費(fèi)用為0的邊即可。

Code

#include<cstdio>const int N=605,M=66005,INF=~0U>>2;int i,m,n,s,t,tmp,x,cnt,ans,l,r,ed=1,u[M],v[M],c[M],co[M],nxt[M],q[M],g[N],f[N],d[N];bool in[N];void add(int x,int y,int z,int zo){ u[++ed]=x,v[ed]=y,c[ed]=z,co[ed]=zo,nxt[ed]=g[x],g[x]=ed; u[++ed]=y,v[ed]=x,c[ed]=0,co[ed]=-zo,nxt[ed]=g[y],g[y]=ed;}bool SPFA(){ for(i=1;i<=t;i++) d[i]=INF,in[i]=0; in[s]=1,q[l=r=M>>1]=s; while(l<=r){ int x=q[l++]; if(x==t) continue; for(i=g[x];i;i=nxt[i]) if(c[i] && d[v[i]]>d[x]+co[i]){ d[v[i]]=d[x]+co[i]; f[v[i]]=i; if(!in[v[i]]){ if(d[v[i]]<d[q[l]]) q[--l]=v[i]; else q[++r]=v[i]; in[v[i]]=1; } } in[x]=0; } return d[t]<INF;}int main(){ scanf("%d%d",&m,&n); tmp=n*m,t=tmp+n+1; for(i=1;i<=n;i++){ add(i+tmp,t,1,0); for(int j=0;j<m;j++){ int p=j*n; scanf("%d",&x); for(int k=1;k<=n;k++) add(p+k,i+tmp,1,k*x); } } for(i=1;i<=tmp;i++) add(s,i,1,0); while(SPFA()){ for(tmp=INF,i=t;i!=s;i=u[f[i]]) if(tmp>c[f[i]]) tmp=c[f[i]]; for(ans+=d[i=t]*tmp;i!=s;i=u[f[i]]) c[f[i]]-=tmp,c[f[i]^1]+=tmp; } printf("%.2f",ans/(double)n); return 0;}
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 米泉市| 盐山县| 始兴县| 广丰县| 梅州市| 临汾市| 周口市| 集贤县| 嵊州市| 栾川县| 商洛市| 府谷县| 宣威市| 海丰县| 盱眙县| 漠河县| 古浪县| 中山市| 青浦区| 大竹县| 周宁县| 炎陵县| 图片| 讷河市| 肃北| 上饶市| 滕州市| 宣威市| 河南省| 都昌县| 玉屏| 康乐县| 横峰县| 伊通| 呈贡县| 上杭县| 明溪县| 益阳市| 余江县| 张北县| 洛扎县|