修车修到jiry报废(滑稽)

题意:m个人修n个车,同时开始。

每辆车只能给一个人修。每个人修每辆车的用时都不同。

问怎样安排能使每辆车的等待时间总和最少。

解:

一直想的是用以流量表示一个人,没想到是一流量表示一辆车......

答案统计也想错了...应该是统计每辆车修的时候对它以及它后面车的贡献。

比如当前这辆车的后面还有k辆,那么时间就要乘k + 1

每辆车可以给每个人修,后面可以安排任意辆车。据此拆点,把每个人拆成n个。

源点向车连边,车向每个人的后面有几辆车(一共m * n个点)连边,然后连到汇点。

跑最小费用最大流即可。

 #include <cstdio>
#include <algorithm>
#include <queue>
#include <cstring> const int N = , M = , INF = 0x3f3f3f3f; struct Edge {
int nex, v, c, len;
}edge[M << ]; int top = ; int e[N], d[N], vis[N], pre[N], flow[N];
std::queue<int> Q;
int G[][]; inline void add(int x, int y, int z, int w) {
top++;
edge[top].v = y;
edge[top].c = z;
edge[top].len = w;
edge[top].nex = e[x];
e[x] = top; top++;
edge[top].v = x;
edge[top].c = ;
edge[top].len = -w;
edge[top].nex = e[y];
e[y] = top;
return;
} inline bool SPFA(int s, int t) {
memset(d, 0x3f, sizeof(d));
d[s] = ;
flow[s] = INF;
vis[s] = ;
Q.push(s);
while(!Q.empty()) {
int x = Q.front();
Q.pop();
vis[x] = ;
for(int i = e[x]; i; i = edge[i].nex) {
int y = edge[i].v;
if(edge[i].c && d[y] > d[x] + edge[i].len) {
d[y] = d[x] + edge[i].len;
pre[y] = i;
flow[y] = std::min(flow[x], edge[i].c);
if(!vis[y]) {
vis[y] = ;
Q.push(y);
}
}
}
}
return d[t] < INF;
} inline void update(int s, int t) {
int temp = flow[t];
while(t != s) {
int i = pre[t];
edge[i].c -= temp;
edge[i ^ ].c += temp;
t = edge[i ^ ].v;
}
return;
} inline int solve(int s, int t, int &cost) {
int ans = ;
cost = ;
while(SPFA(s, t)) {
ans += flow[t];
cost += flow[t] * d[t];
update(s, t);
}
return ans;
} int m;
inline int id(int x, int y) {
return (x - ) * m + y;
} int main() { int n;
scanf("%d%d", &m, &n);
for(int i = ; i <= n; i++) {
for(int j = ; j <= m; j++) {
scanf("%d", &G[i][j]);
}
}
int s = (m + ) * n + ;
int t = s + ;
for(int a = ; a <= n; a++) {
add(s, a, , );
for(int j = ; j <= m; j++) {
for(int i = ; i <= n; i++) {
add(a, n + id(i, j), , i * G[a][j]);
}
}
for(int j = ; j <= m; j++) {
add(n + id(a, j), t, , );
}
}
int ans;
solve(s, t, ans);
printf("%.2f", 1.0 * ans / n);
return ;
}

AC代码

最新文章

  1. ASP.NET MVC Html.BeginForm 设置 timeout
  2. placeholder 使用
  3. 苹果IPSW文件提取软件
  4. mysql命令(数据库备份与恢复)
  5. nodejs的mysql模块学习(七)连接池事件
  6. [git] 更新到某个指定版本
  7. JAVA的设计模式之单例设计模式
  8. Tomcat配置域名访问
  9. 使用URLConnection提交请求
  10. CodeForces - 589B(暴力)
  11. 关于公众平台接口不再支持HTTP方式调用的公告
  12. VHDL 例程
  13. Apache Ignite 学习笔记(二): Ignite Java Thin Client
  14. sqlplus执行startup出现ORA-00119,ORA-00132错误
  15. Codeforces Round#413 Problem A - C
  16. div和span元素的区别
  17. Kafka设计解析(七)Kafka Stream
  18. Android开发10——Activity的跳转与传值
  19. MySql 快速去重方法
  20. 剑指offer 面试50题

热门文章

  1. 第五节 HTML&amp;CSS -- 关于浮动和清除浮动的解说,以及两个大坑不要踩
  2. libgdx学习记录11——平铺地图TiledMap
  3. libgdx判断矩形重叠碰撞
  4. 爱普生L313彩色打印相片
  5. 激活IntelliJ IDEA到2100年
  6. [转]申瓯 JSY2000-06 程控电话交换机呼叫转移设置
  7. 记录Jenkins+gitlab+maven
  8. (转载)利用SIFT和RANSAC算法(openCV框架)实现物体的检测与定位,并求出变换矩阵(findFundamentalMat和findHomography的比较) 置顶
  9. 获取apk的签名信息
  10. 2013337朱荟潼 Linux第三章读书笔记——进程管理