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

首頁 > 學院 > 開發(fā)設計 > 正文

[BZOJ1927][Sdoi2010]星際競速(費用流)

2019-11-14 09:46:10
字體:
來源:轉載
供稿:網友

題目描述

傳送門

題解

這道題有每一個點經過且只經過一次的限制以為是有上下界的費用流 然后寫寫寫…對是對了,T得好慘 因為加了n2條邊…

實際上這道題一個普通的費用流就能解決了 對于每一個點拆點xiyi s->xi,1,0 s->yi,ai yi->t,1,0 對于能到達的兩個點ij,xi->yj,time 這樣跑一遍費用流就可以了 可以發(fā)現(xiàn)是一定可以滿流的,保證了每一個點都被訪問一次,有點最小路徑覆蓋的意思

代碼

#include<algorithm>#include<iostream>#include<cstring>#include<cstdio>#include<cmath>#include<queue>using namespace std;#define N 80000#define inf 2000000000int n,m,x,y,z,s,t,mincost;int tot,point[N],nxt[N],v[N],remain[N],c[N];int d[N],dis[N],last[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%d",&n,&m); s=n+n+1,t=s+1; for (int i=1;i<=n;++i) { scanf("%d",&x); addedge(s,n+i,1,x); addedge(s,i,1,0); addedge(n+i,t,1,0); } for (int i=1;i<=m;++i) { scanf("%d%d%d",&x,&y,&z); if (x==y) continue; if (x>y) swap(x,y); addedge(x,n+y,inf,z); } while (spfa(s,t));
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: av在线播放电影 | 日韩精品中文字幕一区 | 久久9999久久 | 极品美女一级毛片 | 免费黄色欧美视频 | 色就操 | 国产精品99精品 | 精品在线一区二区三区 | 日本精品视频一区二区三区四区 | 最新av在线免费观看 | 大学生一级毛片 | 精品在线观看一区二区 | 欧美特一级 | xxxx18韩国护士hd老师 | 欧美精品色精品一区二区三区 | 国产精品视频一区二区三区四区国 | 亚洲视频综合网 | 国产精品99久久久久久久女警 | 亚洲第一视频 | 久久91精品国产91久久yfo | 日韩免费黄色 | 一级毛片免费版 | 一级网站片| 美女啪网站 | 黄视频网站免费观看 | 国产大片全部免费看 | 久久影片| 91 免费看片 | 九九热在线视频观看 | 久久精品一区二区三区不卡牛牛 | 亚洲极色 | 人成久久 | 久久精品视频12 | 香蕉视频网站在线观看 | 桥本有菜免费av一区二区三区 | 亚洲成人精品久久久 | 日本精品视频一区二区三区四区 | 国产二区三区视频 | 91成人在线免费观看 | 爱福利视频 | 欧美日韩一 |