HDU - 3572-Task Schedule

题目大意:给N个任务,M台机器。每个任务有最早才能开始做的时间S,最晚完成时间 E,

和持续工作的时间P。每个任务可以由不同的机器进行,但是在同一时刻,一台机器最多只能

执行一个任务. 问存不存在可行的工作时间。

 

思路:网络流建边好蓝啊!!!一直在想怎么用时间 t 建边,好像进入了一个怪圈粗不来!!!

看来题解的思路就懂了,乍一看不是太难嘛,可是自己写就写不来,还是菜啊,哎!!!!!!

我们先设一个s点,然后从s向 每个工作建边,且边的权值为P,然后每个工作向它的起始时间

和结束时间的所有点建边权值为1,然后所有天数向e建边,权值为m。然后跑最大流,如果

最大流等于所有P的和则能完成,否则不能完成。 

ps :还学到了一个优化!!

 1 #include<cstdio>
 2 #include<algorithm>
 3 #include<vector>
 4 #include<queue>
 5 #include<cstring>
 6 using namespace std;
 7 const int N=1010;
 8 const int M=251000+7;
 9 const int inf=0x3f3f3f3f;
10 int e,s,deth[N],n,m,cnt,head[N];
11 bool vis[N];
12 struct node
13 {
14     int t,v,nx;
15 }edge[M<<1];
16 void add(int from,int to,int v)
17 {
18     edge[cnt].t=to;
19     edge[cnt].v=v;
20     edge[cnt].nx=head[from];
21     head[from]=cnt++;
22 
23     edge[cnt].t=from;
24     edge[cnt].v=0;
25     edge[cnt].nx=head[to];
26     head[to]=cnt++;
27 }
28 bool bfs()
29 {
30     memset(deth,0,sizeof(deth));
31     queue<int> Q;
32     Q.push(s); deth[s]=1;
33     while(!Q.empty())
34     {
35         int cur=Q.front(); Q.pop();
36         if(cur==e) return true;
37         for(int i=head[cur];~i;i=edge[i].nx)
38         {
39             int now=edge[i].t;
40             if(!edge[i].v || deth[now]) continue;
41             deth[now]=deth[cur]+1;
42             Q.push(now);
43         }
44     }
45     return false;
46 }
47 int dfs(int cur,int p)
48 {
49     if(cur==e) return p;
50     int res=0;
51     for(int i=head[cur];~i;i=edge[i].nx)
52     {
53         int now=edge[i].t;
54         if(!edge[i].v || deth[now]!=deth[cur]+1) continue;
55         int f=dfs(now,min(p-res,edge[i].v));
56         res+=f;
57         edge[i].v-=f; edge[i^1].v+=f;
58         if(res==p) break;
59     }
60     if(!res) deth[cur]=1; //这个优化一定要加!!!!!
61     return res;
62 }
63 int Dinic()
64 {
65     int ans=0;
66     while(bfs()) ans+=dfs(s,inf);
67     return ans;
68 }
69 void init()
70 {
71     cnt=0;
72     memset(head,-1,sizeof(head));
73 }
74 int main()
75 {
76     int T; scanf("%d",&T);
77     for(int cas=1;cas<=T;cas++)
78     {
79         init();
80         scanf("%d%d",&n,&m);
81         int tot=0; s=0; e=501+n;
82         for(int i=1;i<=n;i++)
83         {
84             int p,f,t; scanf("%d%d%d",&p,&f,&t);
85             tot+=p;
86             add(s,i+500,p);
87             for(int j=f;j<=t;j++) add(i+500,j,1);
88         }
89         for(int i=1;i<=500;i++) add(i,e,m);
90         int ans=Dinic();
91         if(tot==ans) printf("Case %d: Yes\n\n",cas);
92         else printf("Case %d: No\n\n",cas);
93     }
94     return 0;
95 }
View Code

 

转载于:https://www.cnblogs.com/CJLHY/p/7668400.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ava实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),可运行高分资源 Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现
C语言是一种广泛使用的编程语言,它具有高效、灵活、可移植性强等特点,被广泛应用于操作系统、嵌入式系统、数据库、编译器等领域的开发。C语言的基本语法包括变量、数据类型、运算符、控制结构(如if语句、循环语句等)、函数、指针等。下面详细介绍C语言的基本概念和语法。 1. 变量和数据类型 在C语言中,变量用于存储数据,数据类型用于定义变量的类型和范围。C语言支持多种数据类型,包括基本数据类型(如int、float、char等)和复合数据类型(如结构体、联合等)。 2. 运算符 C语言中常用的运算符包括算术运算符(如+、、、/等)、关系运算符(如==、!=、、=、<、<=等)、逻辑运算符(如&&、||、!等)。此外,还有位运算符(如&、|、^等)和指针运算符(如、等)。 3. 控制结构 C语言中常用的控制结构包括if语句、循环语句(如for、while等)和switch语句。通过这些控制结构,可以实现程序的分支、循环和多路选择等功能。 4. 函数 函数是C语言中用于封装代码的单元,可以实现代码的复用和模块化。C语言中定义函数使用关键字“void”或返回值类型(如int、float等),并通过“{”和“}”括起来的代码块来实现函数的功能。 5. 指针 指针是C语言中用于存储变量地址的变量。通过指针,可以实现对内存的间接访问和修改。C语言中定义指针使用星号()符号,指向数组、字符串和结构体等数据结构时,还需要注意数组名和字符串常量的特殊性质。 6. 数组和字符串 数组是C语言中用于存储同类型数据的结构,可以通过索引访问和修改数组中的元素。字符串是C语言中用于存储文本数据的特殊类型,通常以字符串常量的形式出现,用双引号("...")括起来,末尾自动添加'\0'字符。 7. 结构体和联合 结构体和联合是C语言中用于存储不同类型数据的复合数据类型。结构体由多个成员组成,每个成员可以是不同的数据类型;联合由多个变量组成,它们共用同一块内存空间。通过结构体和联合,可以实现数据的封装和抽象。 8. 文件操作 C语言中通过文件操作函数(如fopen、fclose、fread、fwrite等)实现对文件的读写操作。文件操作函数通常返回文件指针,用于表示打开的文件。通过文件指针,可以进行文件的定位、读写等操作。 总之,C语言是一种功能强大、灵活高效的编程语言,广泛应用于各种领域。掌握C语言的基本语法和数据结构,可以为编程学习和实践打下坚实的基础。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值