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

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

[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 這樣跑一遍費用流就可以了 可以發現是一定可以滿流的,保證了每一個點都被訪問一次,有點最小路徑覆蓋的意思

代碼

#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));
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 叶城县| 将乐县| 尉氏县| 鹿邑县| 固阳县| 贵溪市| 七台河市| 沿河| 宝清县| 惠水县| 兰溪市| 安仁县| 马山县| 普定县| 天等县| 新田县| 呼图壁县| 图片| 东丰县| 北安市| 鹿邑县| 文山县| 蒙城县| 谢通门县| 奉贤区| 襄樊市| 互助| 兰州市| 视频| 上饶市| 滕州市| 睢宁县| 丹凤县| 巴南区| 浦城县| 南宫市| 滁州市| 谢通门县| 赞皇县| 余干县| 吉林省|