参考:https://blog.csdn.net/sd_invol/article/details/15813671

要点

  1. 每个任务的结束时间是固定的,不受任何因素影响
  2. 机器只在最一开始有用,在那之后都是任务之间的转换

连边

将任务拆点,入点 i, 出点 i', 连边 (i, i' [1,1], 0)

设源点 s_, 汇点 t_

  1. 对于机器 \(i (i \in [1, m])\), 连 (s_, i, 1, 0),即流量为1,费用为0

    1. 对每个任务 \(j\)

      • 如果 \(C[i][j] \le ss[i]\),连 (i, j, 1, D[i][j])
      • 否则如果 \(C[i][j] < tt[j]\),连 (i, j, 1, D[i][j] + k*(C[i][j] - s[j]))
      • 否则不连边
  2. 对于每个任务 \(i(i\in[1,n])\),
    1. 连 (i, i', [1,1],0), 即流量在 [1,1]范围内,费用为0的边
    2. 连 (i',t_, 1, 0)
    3. 对于另一个任务 j,考虑 i -> j 的转换, 即 \(endTime = tt[i] + E[i][j]\)
      • 如果 \(endTime \le ss[j]\), 连(i', j, 1, F[i][j])
      • 否则如果 \(endTime \lt tt[j]\) ,连 (i', j, 1, F[i][j] + k * (endTime - ss[j]))
      • 否则不连边

然后对该网络求有源汇的上下界网络流即可

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int inf = 0x3f3f3f3f;
#define dbg(x...) do { cout << "\033[32;1m" << #x <<" -> "; err(x); } while (0)
void err() { cout << "\033[39;0m" << endl; }
template<class T, class... Ts> void err(const T& arg,const Ts&... args) { cout << arg << " "; err(args...); }
const int N = 300 + 10;
const int M = 200010;
int n, m, k, s_, t_, s, t;
int ss[N], tt[N];
int C[N][N], D[N][N], E[N][N], F[N][N];
int head[N], nxt[M], ver[M], edge[M], cost[M], tot;
int d[N], v[N], incf[N], pre[N];
int ans, maxflow;
void add(int x, int y, int z, int c){
ver[++tot] = y, edge[tot] = z, nxt[tot] = head[x], head[x] = tot, cost[tot] = c;
ver[++tot] = x, edge[tot] = 0, nxt[tot] = head[y], head[y] = tot, cost[tot] = -c;
}
bool spfa(){
queue<int> q;
memset(d, 0x3f, sizeof d);
memset(v, 0, sizeof v);
q.push(s);
d[s] = 0, v[s] = 1;
incf[s] = inf;
while(q.size()){
int x = q.front();
q.pop();
v[x] = 0;
for (int i = head[x]; i;i=nxt[i]){
if(!edge[i])
continue;
int y = ver[i];
if(d[y] > d[x] + cost[i]){
d[y] = d[x] + cost[i];
incf[y] = min(incf[x], edge[i]);
pre[y] = i;
if(!v[y])
v[y] = 1, q.push(y);
}
}
}
if(d[t] == inf)
return false;
return true;
} void update(){
int x = t;
while(x != s){
int i = pre[x];
edge[i] -= incf[t];
edge[i ^ 1] += incf[t];
x = ver[i ^ 1];
}
maxflow += incf[t];
ans += d[t] * incf[t];
} int main(){
while(~scanf("%d%d%d", &n, &m, &k)){
if(n == 0 && m == 0 && k == 0)break;
tot = 1;
s_ = n + n + m + 1, t_ = s_ + 1, s = t_ + 1, t = s + 1;
for(int i=1;i<=t;i++) head[i] = 0;
ans = 0, maxflow = 0;
for(int i=1;i<=n;i++) scanf("%d%d", &ss[i], &tt[i]);
for(int i=1;i<=n;i++) for(int j=1;j<=m;j++) scanf("%d", &C[j][i]);
for(int i=1;i<=n;i++) for(int j=1;j<=m;j++) scanf("%d", &D[j][i]);
for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) scanf("%d", &E[i][j]);
for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) scanf("%d", &F[i][j]); // (i, i+n, [1,1], 0)
// s 向 出点 (s, i+n, 1, 0)
// 入点 向 t (i, t, 1, 0)
// 出点向t_ (i+n, t_, 1, 0)
for(int i=1;i<=n;i++){
add(s, i+n, 1, 0);
add(i, t, 1, 0);
add(i+n, t_, 1, 0);
}
// s_-> 机器连边 流量1, 费用0
for(int i=1;i<=m;i++){
add(s_, n+n+i, 1, 0);
}
// 机器与任务连边
for(int i=1;i<=m;i++){
int id = 2 * n + i;
for(int j=1;j<=n;j++){
if(C[i][j] <= ss[j]){ //在ss[j]之前就可以准备好
add(id, j, 1, D[i][j]);
} else if(C[i][j] < tt[j]){ // 无法在tt[j] 之前准备好
add(id, j, 1, D[i][j]+k*(C[i][j]-ss[j]));
}
}
}
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
if(i == j) continue;
int endTime = tt[i] + E[i][j];
if(endTime <= ss[j]){
add(i + n, j, 1, F[i][j]);
} else if(endTime < tt[j]) {
add(i + n, j, 1, F[i][j] + k * (endTime - ss[j]));
}
}
}
add(t_, s_, inf, 0);
while(spfa()) update();
if(maxflow != n) puts("-1");
else printf("%d\n", ans);
}
return 0;
}

2013 Asia Hangzhou Regional Contest hdu4780 Candy Factory的更多相关文章

  1. 2013 Asia Hangzhou Regional Contest

    Lights Against Dudely http://acm.hdu.edu.cn/showproblem.php?pid=4770 15个位置,所以可以暴力枚举那些放,对于放的再暴力枚举哪个转, ...

  2. HDU4771(2013 Asia Hangzhou Regional Contest )

    http://acm.hdu.edu.cn/showproblem.php?pid=4771 题目大意: 给你一幅图(N*M)“@”是起点,"#"是墙,“.”是路,然后图上有K个珠 ...

  3. HDU 3685 Rotational Painting(多边形质心+凸包)(2010 Asia Hangzhou Regional Contest)

    Problem Description Josh Lyman is a gifted painter. One of his great works is a glass painting. He c ...

  4. HDU 3686 Traffic Real Time Query System(双连通分量缩点+LCA)(2010 Asia Hangzhou Regional Contest)

    Problem Description City C is really a nightmare of all drivers for its traffic jams. To solve the t ...

  5. 2012 Asia Hangzhou Regional Contest

    Friend Chains http://acm.hdu.edu.cn/showproblem.php?pid=4460 图的最远两点距离,任意选个点bfs,如果有不能到的点直接-1.然后对于所有距离 ...

  6. 2013 Asia Chengdu Regional Contest

    hdu 4786 Fibonacci Tree http://acm.hdu.edu.cn/showproblem.php?pid=4786 copyright@ts 算法源于ts,用最小生成树可以求 ...

  7. HDU 3689 Infinite monkey theorem(DP+trie+自动机)(2010 Asia Hangzhou Regional Contest)

    Description Could you imaging a monkey writing computer programs? Surely monkeys are smart among ani ...

  8. 2013 Asia Changsha Regional Contest---Josephina and RPG(DP)

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=4800 Problem Description A role-playing game (RPG and ...

  9. zoj 3659 Conquer a New Region The 2012 ACM-ICPC Asia Changchun Regional Contest

    Conquer a New Region Time Limit: 5 Seconds      Memory Limit: 32768 KB The wheel of the history roll ...

随机推荐

  1. 使用uiautomatorviewer报错Error obtaining UI hierarchy

    现象:使用uiautomatorviewer报错Error obtaining UI hierarchy 解决方法:经验证关闭appium,再重新获取,就不会报错     (python运行了app代 ...

  2. .NET 云原生架构师训练营(模块二 基础巩固 RabbitMQ Masstransit 介绍)--学习笔记

    2.6.6 RabbitMQ -- Masstransit 介绍 Masstransit 是什么 Quickstart 消息 Message Masstransit 是什么 Masstransit 是 ...

  3. Angular入门到精通系列教程(10)- 指令(Directive)

    1. 摘要 2. 组件与指令之间的关系 2.1. 指令的种类 3. Angular 中指令的用途 4. 指令举例 4.1. 指令功能 4.2. Anuglar CLI生成基本文件 4.3. Direc ...

  4. 天梯赛练习 L3-010 是否完全二叉搜索树 (30分) 数组建树模拟

    题目分析: 本题的要求是将n个数依次插入一个空的二叉搜索树(左大右小,且没有重复数字),最后需要输出其层次遍历以及判断是否是完全二叉搜索树,通过观察我们发现, 如果这个树是用数组建立的,那么最后输出的 ...

  5. #2020征文-开发板# 用鸿蒙开发AI应用(五)HDF 驱动补光灯

    目录: 前言 硬件准备 HDF 驱动开发 总结 前言上一篇,我们在鸿蒙上运行了第一个程序,这一篇我们来编写一个驱动开启摄像头的红外补光灯,顺便熟悉一下鸿蒙上的 HDF 驱动开发. 硬件准备先查一下原理 ...

  6. 【SpringBoot】Spring Boot 集成SwaggerAPI

    Spring Boot 集成SwaggerAPI 文章目录 Spring Boot 集成SwaggerAPI Swagger 添加依赖 配置类 config 控制类 controller 接口测试 页 ...

  7. SAP表的锁定与解锁

    表的锁定模式有三种模式. lock mode有三种模式:分别是S,E,X.含义如下:     S (Shared lock, read lock)     E (Exclusive lock, wri ...

  8. PW2320芯片N沟道增强型MOSFET

    PW2320采用先进的沟道技术,以提供优良的RDS(ON),低栅电荷和电压门极电压低至2.5V时工作.该装置适合用作电池保护或在其他开关应用中. 特征 VDS=20V ID=8A RDS(开)< ...

  9. 运用 pyinstaller 打包的python exe文件运行 去掉命令行窗口及其他参数汇总

    运行exe文件的时候,会弹出一个dos命令窗口,这个窗口可以看到一些打印信息,如果想只运行tkinter 页面,去掉dos窗口需要在打包的时候 加上 -w 参数 pyinstaller -F XX.p ...

  10. Vue之优化封装请求方法

    Vue之优化封装请求方法 对于代码中的请求操作 1.接口请求可能需要重用 2.实际工作中,接口非常容易变动, 改起来很麻烦! 我们建议的做法是把所有的请求都封装成函数然后统一的>###组织到模块 ...