最大流Sap模板

int dfs(int u,int augu){
    int augv=0,v,delta,mind= n-1;
    if(u==T)
        return augu;
    for(v=S;v<=T;v++)
        if(cap[u][v]>0){
            if(dist[u]==dist[v]+1){
                delta=min(augu-augv,cap[u][v]);
                delta=dfs(v,delta);
                cap[u][v]-=delta;
                cap[v][u]+=delta;
                augv+=delta;
                if(augv==augu)
                    return augv;
                if(dist[S]>=n)
                    return augv;
            }
            mind=min(mind,dist[v]);
        }
    if(!augv){
        vd[dist[u]]--;
        if(!vd[dist[u]])
            dist[S]=n;
        dist[u]=mind+1;
        vd[dist[u]]++;
    }
    return augv;
}
void sap(){
    n=T+1;
    vd[0]=n;
    while(dist[S]<n)
        flow+=dfs(S,INF);
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值