题目

只能做网络流度日了

当然是要对每个修车的人拆点,把每个人拆成\(n\)个点用于接收不同时刻的车

每个车\(i\)向每个时刻\(k\)的人\(j\)连边,边权为\(t[i][j]*k\)这样就是这样修的等待时间了

代码

#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<queue>
#define re register
#define maxn 545
#define LL long long
#define inf 999999999
#define max(a,b) ((a)>(b)?(a):(b))
#define min(a,b) ((a)<(b)?(a):(b))
inline int read()
{
char c=getchar();int x=0;
while(c<'0'||c>'9') c=getchar();
while(c>='0'&&c<='9') x=(x<<3)+(x<<1)+c-48,c=getchar();return x;
}
struct E{int v,nxt,w,f;}e[maxn*maxn*2];
int S,T,head[maxn],d[maxn],vis[maxn];
int a[maxn][maxn];
int id[10][105];
int n,m,num=1,ans;
inline void add(int x,int y,int ca,int z) {e[++num].v=y;e[num].nxt=head[x];head[x]=num;e[num].w=z;e[num].f=ca;}
inline void C(int x,int y,int ca,int z) {add(x,y,ca,z),add(y,x,0,-1*z);}
std::queue<int> q;
inline int SPFA()
{
for(re int i=S;i<=T;i++) d[i]=inf,vis[i]=0;
q.push(T),d[T]=0;
while(!q.empty())
{
int k=q.front();q.pop();vis[k]=0;
for(re int i=head[k];i;i=e[i].nxt)
if(e[i^1].f&&d[e[i].v]>d[k]+e[i^1].w)
{
d[e[i].v]=d[k]+e[i^1].w;
if(!vis[e[i].v]) q.push(e[i].v),vis[e[i].v]=0;
}
}
return d[S]<inf;
}
int dfs(int x,int now)
{
if(x==T||!now) return now;
int flow=0,ff;vis[x]=1;
for(re int i=head[x];i;i=e[i].nxt)
if(!vis[e[i].v]&&e[i].f&&d[x]+e[i^1].w==d[e[i].v])
{
ff=dfs(e[i].v,min(now,e[i].f));
if(ff<=0) continue;
e[i].f-=ff,e[i^1].f+=ff;
now-=ff,flow+=ff;
if(!now) break;
}
return flow;
}
int main()
{
m=read(),n=read();
for(re int i=1;i<=n;i++)
for(re int j=1;j<=m;j++) a[i][j]=read();
T=n;
for(re int i=1;i<=m;i++)
for(re int j=1;j<=n;j++)
id[i][j]=++T;
++T;
for(re int i=1;i<=n;i++) C(S,i,1,0);
for(re int i=1;i<=m;i++)
for(re int j=1;j<=n;j++)
C(id[i][j],T,1,0);
for(re int i=1;i<=n;i++)
for(re int j=1;j<=m;j++)
for(re int k=1;k<=n;k++)
C(i,id[j][k],1,k*a[i][j]);
while(SPFA())
{
vis[T]=1;
while(vis[T])
{
for(re int i=S;i<=T;i++) vis[i]=0;
ans+=dfs(S,inf)*d[S];
}
}
printf("%.2lf\n",(double)ans/double(n));
return 0;
}

最新文章

  1. 【Win 10 应用开发】在App所在的进程中执行后台任务
  2. ZOJ Problem Set - 1241 Geometry Made Simple
  3. CocoaPods的使用及安装
  4. html快速入门(基础教程+资源推荐)
  5. 【转】 #1451 - Cannot delete or update a parent row: a foreign key constraint fails 问题的解决办法
  6. 概述Log4j简介
  7. Python3 学习第十二弹: 补充something
  8. Linux下如何卸载HP_LoadGenerator
  9. POJ 3616 DP
  10. c++重点知识点
  11. MySQL- 锁机制及MyISAM表锁
  12. UI和UE有什么区别呢?
  13. 生成 HTMLTestRunner 测试报告学习总结
  14. 九、Python+Selenium模拟用QQ登陆腾讯课堂,并提取报名课程(练习)
  15. flex与js通信、在浏览器中打开新窗口
  16. Python——Django-manage.py的内容
  17. Django之URL(路由系统)用法
  18. 如何在《救赎之路》中使用CPU粒子效果
  19. Phabricator 在 centos 系统下发送 Email的配置
  20. 解密DNSPOD应对DDoS攻击招式!

热门文章

  1. oracle 控制文件损坏处理
  2. CenctOS6 and CenctOS7 多种姿势解决忘记密码
  3. pipline --学习 (-)
  4. 九度oj题目1027:欧拉回路
  5. [Modelsim] 仿真的基本操作
  6. 【学习笔记】String进阶:StringBuffer类(线程安全)和StringBuilder类
  7. PHP常用的一些数组操作总结
  8. 【Linux】安装Nginx
  9. C++里创建 Trie字典树(中文词典)(三)(联想)
  10. HihoCoder#1279 : Rikka with Sequence(dp 枚举子集 二进制 神仙题)