题意:有N个作业,M台机器,每个作业1天只能同1台机器运行,每台机器1天只能运行1个作业,第i个作业需要pi天完成,且只能从Si到Ei中选Pi天,问能否完成所有作业(T <= 20, N<=500, M<=200, 1 <= Pi, Si, Ei <= 500)。

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3572

——>>建图思路原来是这样子:设一个超级源s,每个作业为1个结点,从s往每个作业分别连1条边,容量为完成该作业所需的时间,那么从s发出满流时,就是作业所需天数,最后就看最大流是否为满流即可;作业可选择的天也分别作为1个结点,每个作业分别向其可选择的天连1条边,容量为1(因为每个作业1天只能同1台机器运行,每台机器1天只能运行1个作业);最后,所有可选择的天分别向超级汇t连1条边,容量为M(因为每天最多只有M台机器)~ok~

#include <cstdio>
#include <vector>
#include <queue>
#include <algorithm>
#include <cstring> using namespace std; const int maxn = 1000 + 10;
const int INF = 0x3f3f3f3f; int N, M;
bool flag[maxn]; struct Edge{
int u, v, cap, flow;
Edge(int u = 0, int v = 0, int cap = 0, int flow = 0):
u(u), v(v), cap(cap), flow(flow){}
}; struct Dinic{
vector<Edge> edges;
vector<int> G[maxn];
int m, s, t;
int d[maxn], cur[maxn];
bool vis[maxn]; void addEdge(int u, int v, int cap){
edges.push_back(Edge(u, v, cap, 0));
edges.push_back(Edge(v, u, 0, 0));
m = edges.size();
G[u].push_back(m-2);
G[v].push_back(m-1);
} bool bfs(){
d[s] = 0;
memset(vis, 0, sizeof(vis));
queue<int> qu;
qu.push(s);
vis[s] = 1;
while(!qu.empty()){
int u = qu.front(); qu.pop();
int sz = G[u].size();
for(int i = 0; i < sz; i++){
Edge& e = edges[G[u][i]];
if(!vis[e.v] && e.cap > e.flow){
d[e.v] = d[u] + 1;
vis[e.v] = 1;
qu.push(e.v);
}
}
}
return vis[t];
} int dfs(int u, int a){
if(u == t || a == 0) return a;
int f, flow = 0;
int sz = G[u].size();
for(int i = cur[u]; i < sz; i++){
Edge& e = edges[G[u][i]];
cur[u] = i;
if(d[e.v] == d[u] + 1 && (f = dfs(e.v, min(a, e.cap-e.flow))) > 0){
e.flow += f;
edges[G[u][i]^1].flow -= f;
flow += f;
a -= f;
if(!a) break;
}
}
return flow;
} int Maxflow(int s, int t){
this->s = s;
this->t = t;
int flow = 0;
while(bfs()){
memset(cur, 0, sizeof(cur));
flow += dfs(s, INF);
}
return flow;
} }; int main()
{
int T, P, S, E, kase = 1;
scanf("%d", &T);
while(T--){
Dinic din;
scanf("%d%d", &N, &M);
memset(flag, 0, sizeof(flag));
int sum = 0;
for(int i = 1; i <= N; i++){
scanf("%d%d%d", &P, &S, &E);
din.addEdge(0, i, P);
for(int j = S; j <= E; j++){
din.addEdge(i, N+j, 1);
if(!flag[N+j]){
din.addEdge(N+j, 1001, M);
flag[N+j] = 1;
}
}
sum += P;
}
if(din.Maxflow(0, 1001) == sum) printf("Case %d: Yes\n\n", kase++);
else printf("Case %d: No\n\n", kase++);
}
return 0;
}

hdu - 3572 - Task的更多相关文章

  1. HDU 3572 Task Schedule(拆点+最大流dinic)

    Task Schedule Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) To ...

  2. HDU 3572 Task Schedule (最大流)

    C - Task Schedule Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u S ...

  3. hdu 3572 Task Schedule (dinic算法)

    pid=3572">Task Schedule Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 ...

  4. hdu 3572 Task Schedule 网络流

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3572 Our geometry princess XMM has stoped her study i ...

  5. HDU 3572 Task Schedule(ISAP模板&amp;&amp;最大流问题)

    题目链接:http://acm.hdu.edu.cn/showproblem.php? pid=3572 题意:m台机器.须要做n个任务. 第i个任务.你须要使用机器Pi天,且这个任务要在[Si  , ...

  6. hdu 3572 Task Schedule

    Task Schedule 题意:有N个任务,M台机器.每一个任务给S,P,E分别表示该任务的(最早开始)开始时间,持续时间和(最晚)结束时间:问每一个任务是否能在预定的时间区间内完成: 注:每一个任 ...

  7. hdu 3572 Task Schedule(最大流&amp;&amp;建图经典&amp;&amp;dinic)

    Task Schedule Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) To ...

  8. 解题报告:hdu 3572 Task Schedule(当前弧优化Dinic算法)

    Problem Description Our geometry princess XMM has stoped her study in computational geometry to conc ...

  9. hdu 3572 Task Schedule (Dinic模板)

    Problem Description Our geometry princess XMM has stoped her study in computational geometry to conc ...

随机推荐

  1. 「JAVA」:Berkeley DB的JAVA连接

    Berkeley DB是一个嵌入式的数据库,它适合于管理海量的.简单的数据.关键字/数据(key/value)是Berkeley DB用来进行数据管理的基础.每个key/value构成了一条记录,而整 ...

  2. Android开发 第一篇

    关于android开发,new项目通知: 之前的new -> android project,现在更改为new -> android application project,同学们可以继续 ...

  3. Codeforces 41D Pawn 简单dp

    题目链接:点击打开链接 给定n*m 的矩阵 常数k 以下一个n*m的矩阵,每一个位置由 0-9的一个整数表示 问: 从最后一行開始向上走到第一行使得路径上的和 % (k+1) == 0 每一个格子仅仅 ...

  4. caffe神经网络框架的辅助工具(将图片转换为leveldb格式)

    caffe中负责整个网络输入的datalayer是从leveldb里读取数据的,是一个google实现的很高效的kv数据库. 因此我们训练网络必须先把数据转成leveldb的格式. 这里我实现的是把一 ...

  5. 【Eclipse】离线插件安装

    1.在eclipse里根目录里,dropins里建一个目录,名字叫sonar(这个名字随便),再在svn下面建一个目录eclipse.在根目录里建一个目录links目录,并建一个sonar.link文 ...

  6. Ubuntu设置为命令行登录

    root@ubuntu:~# vi /etc/default/grub 改: #GRUB_CMDLINE_LINUX_DEFAULT="quiet splash" GRUB_CMD ...

  7. [Swust OJ 249]--凸包面积

        题目链接:    http://acm.swust.edu.cn/problem/0249/   麦兜是个淘气的孩子.一天,他在玩钢笔的时候把墨水洒在了白色的墙上.再过一会,麦兜妈就要回来了, ...

  8. BZOJ 2060: [Usaco2010 Nov]Visiting Cows 拜访奶牛( dp )

    树形dp..水 ------------------------------------------------------------------------ #include<cstdio& ...

  9. Strange Country II 暴力dfs

    这题点的个数(<=50)有限, 所以可以纯暴力DFS去搜索 //#pragma comment(linker, "/STACK:16777216") //for c++ Co ...

  10. 数据结构C语言版 表插入排序 静态表

    数据结构C语言版 表插入排序.txt两个人吵架,先说对不起的人,并不是认输了,并不是原谅了.他只是比对方更珍惜这份感情./*  数据结构C语言版 表插入排序  算法10.3 P267-P270  编译 ...