hdu 3572 Task Schedule【 最大流 】
求出最大流,再判断是否满流
先不理解为什么要这样建图
后来看了这一篇题解
http://blog.csdn.net/u012350533/article/details/12361003
把0看做源点st
把每一个任务看做一个点
st到每个任务连边,容量为p,表示任务完成需要的天数
每个任务到每个任务的开始至结束时间连边,容量为1,表示这个任务可以在这些天完成
每一天向汇点ed连边,容量为m,表示一天最多运行m个任务
然后判断最大流是否等于执行完所有任务所需要的时间
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<queue>
using namespace std; const int maxn = ;
const int INF = ( << ) - ; struct Edge{
int v,next,c;
}e[*maxn]; int st,ed,lev[maxn],first[maxn],now[maxn],ecnt;
int n,m; void init(){
memset(first,-,sizeof(first));
ecnt = ;
} void addedges(int u,int v,int c){
e[ecnt].next = first[u];
e[ecnt].v = v;
e[ecnt].c = c;
first[u] = ecnt++; e[ecnt].next = first[v];
e[ecnt].v = u;
e[ecnt].c = ;
first[v] = ecnt++;
} bool bfs(){
queue<int> q;
while(!q.empty()) q.pop();
q.push(st);
memset(lev,-,sizeof(lev));
lev[st] = ;
while(!q.empty()){
int x = q.front();q.pop();
for(int i = first[x];~i;i = e[i].next){
int v = e[i].v;
if(lev[v] < && e[i].c > ){
lev[v] = lev[x] + ;
q.push(v);
}
}
}
return lev[ed] != -;
} int dfs(int p,int minf){
if(p == ed || minf == ) return minf;
for(int &i = now[p];~i;i = e[i].next){
int v = e[i].v;
if(lev[v] == lev[p] + && e[i].c > ){
int d = dfs(v,min(e[i].c,minf));
if(d > ){
e[i].c -= d;
e[i^].c += d;
return d;
}
}
}
return ;
} int dinic(){
int max_flow = ,p1;
while(bfs()){
memcpy(now,first,sizeof(first));
while((p1 = dfs(st,INF)) > )
max_flow += p1;
}
return max_flow;
} int main(){
int T;
int kase = ;
scanf("%d",&T);
while(T--){
scanf("%d %d",&n,&m);
init();
st = ;
int maxx = -;
int sum = ;
for(int i = ;i <= n;i++){
int p,s,e;
scanf("%d %d %d",&p,&s,&e);sum+=p;
maxx = max(maxx,e);
addedges(st,i,p);
for(int j = s;j <= e;j++) addedges(i,j+n,);
} ed = n + maxx + ;
for(int j = ;j <= maxx;j++) addedges(j+n,ed,m); int ans = dinic();
printf("Case %d: ",++kase);
if(ans == sum) puts("Yes");
else puts("No");
puts("");
}
return ;
}
hdu 3572 Task Schedule【 最大流 】的更多相关文章
- HDU 3572 Task Schedule (最大流)
		
C - Task Schedule Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u S ...
 - hdu 3572 Task Schedule (dinic算法)
		
pid=3572">Task Schedule Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 ...
 - HDU 3572 Task Schedule(拆点+最大流dinic)
		
Task Schedule Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) To ...
 - hdu 3572 Task Schedule(最大流&&建图经典&&dinic)
		
Task Schedule Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) To ...
 - hdu 3572 Task Schedule
		
Task Schedule 题意:有N个任务,M台机器.每一个任务给S,P,E分别表示该任务的(最早开始)开始时间,持续时间和(最晚)结束时间:问每一个任务是否能在预定的时间区间内完成: 注:每一个任 ...
 - 图论--网络流--最大流 HDU  3572 Task Schedule(限流建图,超级源汇)
		
Problem Description Our geometry princess XMM has stoped her study in computational geometry to conc ...
 - hdu 3572 Task Schedule(最大流)2010 ACM-ICPC Multi-University Training Contest(13)——Host by UESTC
		
题意: 告诉我们有m个任务和k个机器.第i个任务需要ci天完成,最早从第ai天开始,最晚在第bi天结束.每台机器每天可以执行一个任务.问,是否可以将所有的任务都按时完成? 输入: 首行输入一个整数t, ...
 - HDU 3572 Task Schedule(最大流判断满流)
		
https://vjudge.net/problem/HDU-3572 题意: 有N个作业和M台机器,每个作业都有一个持续时间P,工作的日期为S~E.作业可以断断续续的在不同机器上做,每台机器每次只可 ...
 - hdu 3572 Task Schedule 网络流
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3572 Our geometry princess XMM has stoped her study i ...
 
随机推荐
- 创建一个dynamics CRM workflow (二) - Build in Workflows
			
这里我们不着重讲解build in workflow. 但是, 如果要上手custom workflow, 我们必须要了解 build in workflow. build-in workflow 在 ...
 - 基于 vue2 导航栏透明渐变
			
在移动或者app 中经常会用,顶部导航栏固定,但是随着页面向上滚动,导航栏的透明度发生变化. 做法为: 1.首先给要滚动变化的导航添加 :style="style" <mt- ...
 - day06-08面向对象的三大特性
			
一.继承 1.1什么是继承?继承是一种创建新类的方式,在python中,新建的类可以继承一个或多个父类,父类又可称为基类或超类,新建的类称为派生类或子类python中类的继承分为:单继承和多继承 cl ...
 - jQuery中Ajax的几种写法
			
1. $.post(url,params,callback); 采用post方式提交,中文参数无需转码,在callback中如果要获取json字符串,还需转换一下. 2. $.getJSON(u ...
 - public static final 的用法
			
public satic final 修饰后变量的名字全部用大写,定以后可以用类名直接访问,定义的变量不能被修改 所有的接口成员已经是静态,由于接口没有方法所有所以必须先赋值才行,可以直接用接口名调用 ...
 - JS棋盘
			
有一个棋盘,有64个方格,在第一个方格里面放1粒芝麻重量是0.00001kg, 第二个里面放2粒,第三个里面放4,棋盘上放的所有芝麻的重量 <!DOCTYPE html> <html ...
 - select的option触发事件
			
<!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8&quo ...
 - Project Euler 14 Longest Collatz sequence
			
题意:对于任意一个数 N ,寻找在 100,0000 之内按照规则( N 为奇数 N = N * 3 + 1 ,N 为偶数 N = N / 2 ,直到 N = 1 时的步数 )步数的最大值 思路:记忆 ...
 - PyCharm中导入MySQLDB模块小结
			
安装完MySQL-python驱动,在PyCharm中导入MySQLDB模块一直不成功 Settings里面也没有MySQLdb 百般尝试找解决办法,一直搞不定,最后抱着试一试的心态尝试了一个办法: ...
 - PHP图片验证码处理