当前位置: 首页 > news >正文

自助建站免费信息发布网站/上海网站推广服务

自助建站免费信息发布网站,上海网站推广服务,个人建筑资格证书查询,wordpress换域名空间\(\\\) Description 有 \(n\) 种货物和 \(n\) 个仓库,开始第 \(i\) 个仓库里有 \(a_{ij}\) 个第 \(j\) 种货物。 现在要让每种货物都只放到一个仓库里,且一个仓库只放一种货物。 货物将在仓库之间移动,总代价就是移动的所有货物的总重。 现不…

\(\\\)

Description


\(n\) 种货物和 \(n\) 个仓库,开始第 \(i\) 个仓库里有 \(a_{ij}\) 个第 \(j\) 种货物。

现在要让每种货物都只放到一个仓库里,且一个仓库只放一种货物。

货物将在仓库之间移动,总代价就是移动的所有货物的总重。

现不指定哪种货物放到哪个仓库里,求最小总代价。

  • \(n\le 150,a_{ij}\le 100\)

\(\\\)

Solution


一开始的想法是把限制加到流量上,后来发现不行。

为什么呢?首先这题的建图肯定是一侧货物一侧仓库。

如果是货物 \(\to\) 仓库,我们无法确定最后哪个仓库放哪种货物,所以仓库向汇点的流量无法限制。

如果是仓库 \(\to\) 货物,我们又无法确定每个仓库向每个货物的流量了,因为我们不知道这种货物是否放回到这个仓库里,进而代价会算多 \((\) 有的边费用可能是 \(0\) 没有算上 \()\)

\(\\\)

因此我们要把代价加到费用上。

考虑此题的限制:

  • 每种货物只能放到一个仓库里
  • 每个仓库只能放一种货物

于是原点连出和连入汇点的所有边流量都是 \(1\) ,代表如上限制。

我们预处理 \(sum_i\) 表示第 \(i\) 种货物的总量。

\(\\\)

如果源连货物,货物指向仓库,仓库连汇,则建图方式:

因为是货物向仓库连边,那么如果这一货物要放到这一仓库,原本在这一仓库的此货物就不用产生代价,其他的这一货物都要产生代价。

货物 \(j\) 向仓库 \(i\) 要连一条流量为 \(1\) ,费用为 \(sum_j-a_{ij}\) 的边。

\(\\\)

如果源连仓库,仓库指向货物,货物连汇,则建图方式:

此时所谓的货物,其实是代表的存放这一货物的仓库。

而仓库连向货物,代价就应该是令这一仓库作为存放这一货物的代价。

显然费用和原来思考方式相同。

\(\\\)

Code


将第二种建图方式的代码放在了注释里。

#include<cmath>
#include<queue>
#include<cstdio>
#include<cctype>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define N 310
#define M 50010
#define R register
#define gc getchar
#define inf 1000000000
using namespace std;inline int rd(){int x=0; bool f=0; char c=gc();while(!isdigit(c)){if(c=='-')f=1;c=gc();}while(isdigit(c)){x=(x<<1)+(x<<3)+(c^48);c=gc();}return f?-x:x;
}int n,m,s,t,tot=1,maxn;int hd[N],pre[N],id[N],dis[N],w[N][N],sum[N];struct edge{int f,w,to,nxt;}e[M];inline void add(int u,int v,int f,int w){e[++tot].to=v; e[tot].w=w;e[tot].f=f; e[tot].nxt=hd[u]; hd[u]=tot;
}bool vis[N];queue<int> q;inline bool spfa(){for(R int i=1;i<=maxn;++i) dis[i]=inf,vis[i]=0;dis[s]=0; q.push(s);while(!q.empty()){int u=q.front();q.pop(); vis[u]=0;for(R int i=hd[u],v;i;i=e[i].nxt)if(e[i].f&&(dis[v=e[i].to]>dis[u]+e[i].w)){dis[v]=dis[u]+e[i].w;pre[v]=u; id[v]=i;if(!vis[v]) vis[v]=1,q.push(v);}}return dis[t]<inf;
}inline int mcmf(){int res=0,tmp;while(spfa()){tmp=inf;for(R int i=t;i!=s;i=pre[i]) tmp=min(tmp,e[id[i]].f);for(R int i=t;i!=s;i=pre[i]){e[id[i]].f-=tmp; e[id[i]^1].f+=tmp;}res+=tmp*dis[t];}return res;
}int main(){n=rd();s=0; maxn=t=(n<<1)+1;for(R int i=1;i<=n;++i){add(s,i,1,0); add(i,s,0,0);add(n+i,t,1,0); add(t,n+i,0,0);for(R int j=1;j<=n;++j) w[i][j]=rd();}for(R int i=1;i<=n;++i)for(R int j=1;j<=n;++j) sum[j]+=w[i][j];for(R int i=1;i<=n;++i)for(R int j=1;j<=n;++j){add(j,n+i,1,sum[j]-w[i][j]);add(n+i,j,0,w[i][j]-sum[j]);}/*for(R int i=1;i<=n;++i)for(R int j=1;j<=n;++j){add(i,n+j,1,sum[j]-w[i][j]);add(n+j,i,0,w[i][j]-sum[j]);}*/printf("%d\n",mcmf());return 0;
}

转载于:https://www.cnblogs.com/SGCollin/p/9959690.html

http://www.lbrq.cn/news/735121.html

相关文章:

  • 网站建设预算/免费p站推广网站入口
  • 华大集团 做网站/软件推广赚钱
  • 安徽炒股配资网站开发/百度广告开户流程
  • wordpress修改时区/长沙网站优化对策
  • wps2016怎么做网站/百度推广seo怎么学
  • app和网站的区别是什么/免费友链平台
  • 长沙做官方网站/站长工具seo下载
  • 外国人学做中国菜的网站/seo原创工具
  • 公益事业做网站/刷神马seo排名首页排名
  • 提高网站建设水平/网站关键词免费优化
  • 网站怎么做抽奖/网站建设一条龙
  • 长治市人民政府门户网站/北京网站建设公司
  • 网站开发技术论文/seo chinaz
  • 做企业网站有哪些系统/高端seo服务
  • 给自己的网站起名字/经典软文广告案例
  • 网站一般用什么做的/重庆百度快速优化
  • 北京网站制作公司哪家好/宝鸡seo
  • 做商城网站都需要什么/东莞网站建设制作
  • 网站建设怎么样找客户快/网站设计说明
  • 朋友说是做彩票网站运营维护/淘宝产品关键词排名查询
  • 用c语言做网站/东莞seo公司
  • 网页设计作业报告范文/对seo的理解
  • 建行国际互联网网站/营销技巧有哪些
  • 中山网站网站建设/外贸推广方式
  • 武汉网站建设公司排名/百度最新版本2022
  • 宝安小学网站建设/全网营销平台
  • 摄影工作室网站建设模板/制作网站的软件叫什么
  • 住房城乡建设局网站首页/企业网站推广优化公司
  • 怎样做网站流量统计/百度推广需要多少钱
  • 企业网站微信公众号的建设事迹/发免费广告电话号码
  • 【lucene】lucene常用查询一览
  • Docker:安装配置
  • pycharm编译器如何快速掌握一个新模块的使用方法
  • 【clion】cmake脚本1:调试脚本并构建Fargo项目win32版本
  • 机器学习概念(面试题库)
  • ‌关于人工智能(AI)的发展现状和未来趋势的详细分析!