2193. 分配问题(最小费用最大流解决最佳二分图问题)

2193. 分配问题(最小费用最大流解决最佳二分图问题)有 n 件工作要分配给 n 个人做。第 i 个人做第 j 件工作产生的效益为 cij。试设计一个将 n 件工作分配给 n 个人做的分配方案。对于给定的 n 件工作和 n 个人,计算最优分配方案和最差分配方案。输入格式第 1 行有 1 个正整数 n,表示有 n 件工作要分配给 n 个人做。接下来的 n 行中,每行有 n 个整数 cij,表示第 i 个人做第 j 件工作产生的效益为 cij。输出格式第一行输出最差分配方案下的最小总效益。第二行输出最优分配方案下的最大总效益。数据范围1≤n≤

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

有 n 件工作要分配给 n 个人做。

第 i 个人做第 j 件工作产生的效益为 cij。

试设计一个将 n 件工作分配给 n 个人做的分配方案。

对于给定的 n 件工作和 n 个人,计算最优分配方案和最差分配方案。

输入格式
第 1 行有 1 个正整数 n,表示有 n 件工作要分配给 n 个人做。

接下来的 n 行中,每行有 n 个整数 cij,表示第 i 个人做第 j 件工作产生的效益为 cij。

输出格式
第一行输出最差分配方案下的最小总效益。

第二行输出最优分配方案下的最大总效益。

数据范围
1≤n≤50,
0≤cij≤100
输入样例:

5
2 2 2 1 2
2 3 1 2 4
2 0 1 1 1
2 3 4 3 3
3 2 1 2 1
输出样例:
5
14
#include<bits/stdc++.h>
using namespace std;
const int N = 2 * 55;
const int M = (50 * 50 + 2 * 50) * 2;
const int INF = 0x3f3f3f3f;
struct Edge{ 
   
    int v,next,w,f;
}edge[M];
int head[N],cnt = 0;
void add(int u,int v,int f,int w){ 
   
    edge[cnt].v = v;
    edge[cnt].f = f;
    edge[cnt].w = w;
    edge[cnt].next = head[u];
    head[u] = cnt ++;
}
int n,m,s,e;
int g[N][N];
int d[N],q[N],hh = 0,tt = 0,pre[N],curf[N],st[N];
bool spfa(){ 
           //最大流最大费用的话就求最长路即可
    memset(d,0x3f,sizeof d);
    memset(curf,0,sizeof curf);
    memset(st,0,sizeof st);
    hh = tt = 0;
    d[s] = 0,q[tt ++] = s,curf[s] = INF;
    st[s] = true;
    while(hh != tt){ 
   
        int t = q[hh ++];
        if(hh == N)hh = 0;
        st[t] = false;
        for(int i = head[t];~i;i = edge[i].next){ 
   
            int v = edge[i].v,w = edge[i].w;
            if(edge[i].f && d[v] > d[t] + w){ 
   
                d[v] = d[t] + w;
                pre[v] = i;
                curf[v] = min(edge[i].f,curf[t]);
                if(!st[v]){ 
   
                    q[tt ++] = v;
                    if(tt == N)tt = 0;
                    st[v] = true;
                }
            }
        }
    }
    return curf[e] > 0;
}
void EK(int &flow,int &cost){ 
   
    flow = cost = 0;
    while(spfa()){ 
   
        int t = curf[e];
        flow += t;cost += t * d[e];
        for(int i = e;i != s;i = edge[pre[i] ^ 1].v){ 
   
            edge[pre[i]].f -= t,edge[pre[i] ^ 1].f += t;
        }
    }
}
int main(){ 
   
    cin>>n;
    memset(head,-1,sizeof head);
    s = 0,e = 2 * n + 1;
    for(int i = 1;i <= n;i ++){ 
   
        for(int j = 1;j <= n;j ++){ 
   
            cin>>g[i][j];
        }
    }
    for(int i = 1;i <= n;i ++){ 
   
        add(s,i,1,0),add(i,s,0,0);
        add(i + n,e,1,0),add(e,i + n,0,0);
    }
    for(int i = 1;i <= n;i ++){ 
   
        for(int j = 1;j <= n;j ++){ 
   
            add(i,n + j,1,g[i][j]),add(j + n,i,0,-g[i][j]);
        }
    }
    int flow = 0,cost = 0;
    EK(flow,cost);
    cout<<cost<<endl;
    for(int i = 0;i < cnt;i += 2){ 
         //求最坏匹配
        edge[i].f += edge[i ^ 1].f;
        edge[i ^ 1].f = 0;
        swap(edge[i].w,edge[i ^ 1].w);
    }
    EK(flow,cost);
    cout<<-cost<<endl;
    return 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168565.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 数据库锁表如何解决_mysql数据库怎么解锁

    数据库锁表如何解决_mysql数据库怎么解锁这个问题之前遇到过一次,但是由于不知道导致锁表的原因,也没细想,就知道表被锁了,然后让别人把表给解锁了。但是前天的一次操作,让我亲眼见证了导致锁表的过程,以及如何给lock的表解锁。1.导致锁表的原因(同志们也可以参考是不是也是同样的操作啊。。。):1.1首先是大前提我们正常的框架在service层都会有事物控制,比如我一个service层的方法要执行更新两张表,这两个表只有同…

    2022年8月23日
    6
  • python random.randint函数用法(random.randint()是什么意思)

    numpy.random.randint(low,high=None,size=None,dtype=’l’)函数的作用是,返回一个随机整型数,范围从低(包括)到高(不包括),即[low,high)。如果没有写参数high的值,则返回[0,low)的值。参数如下:low:int生成的数值最低要大于等于low。(hign=None时,生成的数值要在[0,low)区间内)high:i…

    2022年4月16日
    837
  • 数据库自动化运维平台–自助DML

    数据库自动化运维平台–自助DML今天介绍下最近开发的一个平台,自助DML。什么是DML,就是平常执行的增删改查数据库操作。有人有疑问这不是程序访问的操作,为什么还要做一个平台操作这些呢,其实这种操作主要是开发需要线下修复数据的一种操作,不只是增删改,还有建表,建索引,添加字段等,这些操作开发一般会提给DBA协助操作数据库。可能你会觉得这些活能有多少,其实这种活真不少,我上家公司是电商互联网公司,大概有七八百个实例,每天的这种操作有近百个。处理近百个这种需求,基本上一个人一天就不用干别的了。虽说现在的公司实例少点,但每天的工作量还是很大,关

    2022年5月17日
    45
  • acwing-167. 木棒(深搜dfs+减枝)「建议收藏」

    acwing-167. 木棒(深搜dfs+减枝)「建议收藏」乔治拿来一组等长的木棒,将它们随机地砍断,使得每一节木棍的长度都不超过 50 个长度单位。然后他又想把这些木棍恢复到为裁截前的状态,但忘记了初始时有多少木棒以及木棒的初始长度。请你设计一个程序,帮助乔治计算木棒的可能最小长度。每一节木棍的长度都用大于零的整数表示。输入格式输入包含多组数据,每组数据包括两行。第一行是一个不超过 64 的整数,表示砍断之后共有多少节木棍。第二行是截断以后,所得到的各节木棍的长度。在最后一组数据之后,是一个零。输出格式为每组数据,分别输出原始木棒的可能最小长度

    2022年8月9日
    6
  • 激活成功教程软件下载网站100个[通俗易懂]

    激活成功教程软件下载网站100个[通俗易懂]激活成功教程软件下载网站100个□xuly发表于2005-11-247:48:00

    2022年10月13日
    2
  • 汉明码实现

    汉明码实现汉明码实现 可以利用 matlab 中的 encode 和 decode 实现 但是 下面是自己实现的 m 文件程序功能 1 nbsp HanMingH 生成监督矩阵 nbsp nbsp nbsp nbsp nbsp nbsp 2 HanMingG 生成系统生成矩阵 nbsp nbsp nbsp nbsp nbsp nbsp 3 FindR 计算监督位的数目 nbsp nbsp nbsp nbsp nbsp nbsp 4 FindError 生成错误校正图样 用于纠正错误编码 Main nbsp clc

    2025年11月6日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号