麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

[BZOJ3876][Ahoi2014]支線劇情(有源匯有上下界的費用流)

2019-11-14 08:47:22
字體:
來源:轉載
供稿:網友

題目描述

傳送門

注意這道題是要求每一條邊都被覆蓋,而不是每一個點

題解

原圖的建圖方法: s->1,[0,inf],0 i->t,[0,inf],0 對于給出的一條邊i->j費用為c,連邊i->j,[1,inf],c 然后將這個圖進行改造求有源匯有上下界的費用流即可

但是這道題讓我迷惑的一點是, 原圖如果是求最小費用最大流的話最大流不應該是inf么 大概是因為有源匯有上下界的費用流只是在滿足流量上下界限制的情況下費用最小吧…不一定是最大流

代碼

#include<algorithm>#include<iostream>#include<cstring>#include<cstdio>#include<cmath>#include<queue>using namespace std;#define N 310#define E 20005#define inf 2000000000int n,k,goal,cost,s,t,ss,tt,mincost;int tot,point[N],nxt[E],v[E],remain[E],c[E];int dis[N],last[N],d[N];bool vis[N];queue <int> q;void addedge(int x,int y,int cap,int z){ ++tot; nxt[tot]=point[x]; point[x]=tot; v[tot]=y; remain[tot]=cap; c[tot]=z; ++tot; nxt[tot]=point[y]; point[y]=tot; v[tot]=x; remain[tot]=0; c[tot]=-z;}int addflow(int s,int t){ int now=t,ans=inf; while (now!=s) { ans=min(ans,remain[last[now]]); now=v[last[now]^1]; } now=t; while (now!=s) { remain[last[now]]-=ans; remain[last[now]^1]+=ans; now=v[last[now]^1]; } return ans;}bool spfa(int s,int t){ memset(dis,127,sizeof(dis));dis[s]=0; memset(vis,0,sizeof(vis));vis[s]=1; while (!q.empty()) q.pop();q.push(s); while (!q.empty()) { int now=q.front();q.pop(); vis[now]=0; for (int i=point[now];i!=-1;i=nxt[i]) if (dis[v[i]]>dis[now]+c[i]&&remain[i]) { dis[v[i]]=dis[now]+c[i]; last[v[i]]=i; if (!vis[v[i]]) vis[v[i]]=1,q.push(v[i]); } } if (dis[t]>inf) return 0; int flow=addflow(s,t); mincost+=flow*dis[t]; return 1;}int main(){ tot=-1;memset(point,-1,sizeof(point)); scanf("%d",&n); s=n+1,t=s+1,ss=t+1,tt=ss+1; for (int i=1;i<=n;++i) { scanf("%d",&k); while (k--) { scanf("%d%d",&goal,&cost); --d[i];++d[goal]; addedge(i,goal,inf,cost); } } k=tot; addedge(s,1,inf,0); for (int i=1;i<=n;++i) addedge(i,t,inf,0); for (int i=1;i<=t;++i) { if (d[i]>0) addedge(ss,i,d[i],0); if (d[i]<0) addedge(i,tt,-d[i],0); } addedge(t,s,inf,0); while (spfa(ss,tt)); for (int i=0;i<=k;i+=2) mincost+=c[i];
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧美国产一级片 | 一级黄色大片在线观看 | 久久精品视频亚洲 | 黄视频网站免费在线观看 | 亚洲无线看 | 国产一级桃视频播放 | 91精品片| av在线大全| 国产精品久久久久久久久久久天堂 | 茄子福利视频 | 爱福利视频网 | 欧美精品成人一区二区三区四区 | 国产成人精品免费视频大全最热 | 日韩黄在线观看 | 福利一区二区三区视频在线观看 | 亚洲欧洲日产v特级毛片 | 91麻豆蜜桃一区二区三区 | 日本最新免费二区三区 | 亚洲精品av在线 | 91久久一区 | www.99热精品 | 久久中文一区 | 成人短视频在线观看 | 国内精品伊人久久 | 一级免费 | 成年免费网站 | 高清国产福利 | 亚洲第一视频 | 久久蜜桃香蕉精品一区二区三区 | 91精品国产乱码久久久久久久久 | 久久久成人精品视频 | 国产免费一区二区三区最新不卡 | 91在线观看| 免费观看黄色片视频 | 精品日韩欧美 | 密室逃脱第一季免费观看完整在线 | 色的综合 | 日本中文字幕久久 | 免费在线观看毛片 | 成人男女啪啪免费观看网站四虎 | 91在线视频精品 |