[BZOJ2879] [Noi2012] 美食节 (费用流 动态加边)
Description
CZ市为了欢迎全国各地的同学,特地举办了一场盛大的美食节。作为一个喜欢尝鲜的美食客,小M自然不愿意错过这场盛宴。他很快就尝遍了美食节所有的美食。然而,尝鲜的欲望是难以满足的。尽管所有的菜品都很可口,厨师做菜的速度也很快,小M仍然觉得自己桌上没有已经摆在别人餐桌上的美食是一件无法忍受的事情。于是小M开始研究起了做菜顺序的问题,即安排一个做菜的顺序使得同学们的等待时间最短。小M发现,美食节共有n种不同的菜品。每次点餐,每个同学可以选择其中的一个菜品。总共有m个厨师来制作这些菜品。当所有的同学点餐结束后,菜品的制作任务就会分配给每个厨师。然后每个厨师就会同时开始做菜。厨师们会按照要求的顺序进行制作,并且每次只能制作一人份。此外,小M还发现了另一件有意思的事情: 虽然这m个厨师都会制作全部的n种菜品,但对于同一菜品,不同厨师的制作时间未必相同。他将菜品用1, 2, ..., n依次编号,厨师用1, 2, ..., m依次编号,将第j个厨师制作第i种菜品的时间记为 ti,j 。小M认为:每个同学的等待时间为所有厨师开始做菜起,到自己那份菜品完成为止的时间总长度。换句话说,如果一个同学点的菜是某个厨师做的第k道菜,则他的等待时间就是这个厨师制作前k道菜的时间之和。而总等待时间为所有同学的等待时间之和。现在,小M找到了所有同学的点菜信息: 有 pi 个同学点了第i种菜品(i=1, 2, ..., n)。他想知道的是最小的总等待时间是多少。
Input
Output
输出仅一行包含一个整数,为总等待时间的最小值。
Sample Input
3 2
3 1 1
5 7
3 6
8 9
Sample Output
【样例说明】
厨师1先制作1份菜品2,再制作2份菜品1。点这3道菜的3个同学的等待时间分别为3,3+5=8,3+5+5=13。
厨师2先制作1份菜品1,再制作1份菜品3。点这2道菜的2个同学的等待时间分别为7,7+9=16。
总等待时间为3+8+13+7+16=47。
虽然菜品1和菜品3由厨师1制作更快,如果这些菜品都由厨师1制作,总等待时间反而更长。如果按上述的做法,将1份菜品1和1份菜品3调整到厨师2制作,这样厨师2不会闲着,总等待时间更短。
可以证明,没有更优的点餐方案。
【数据规模及约定】
对于100%的数据,n <= 40, m <= 100, p <= 800, ti,j <= 1000(其中p = ∑pi,即点菜同学的总人数)。
每组数据的n、m和p值如下:
测试点编号 n m p
1 n = 5 m = 5 p = 10
2 n = 40 m = 1 p = 400
3 n = 40 m = 2 p = 300
4 n = 40 m = 40 p = 40
5 n = 5 m = 40 p = 100
6 n = 10 m = 50 p = 200
7 n = 20 m = 60 p = 400
8 n = 40 m = 80 p = 600
9 n = 40 m = 100 p = 800
10 n = 40 m = 100 p = 800
HINT
Source
Solution
和$BZOJ1070$其实是一道题,只不过这道题强制动态加边,并不知道为什么第$2$个点会$TLE$,总之$BZOJ$可以$AC$
1 #include <bits/stdc++.h> 2 using namespace std; 3 struct edge 4 { 5 int u, v, w, c, nxt; 6 }e[80005]; 7 int n, fst[1005], t[45][105], etot = 1, level[1005]; 8 int q[1005], belong[1005], fin[105], pth[1005], use; 9 bool inq[1005]; 10 11 void addedge(int u, int v, int w, int c) 12 { 13 e[++etot] = (edge){u, v, w, c, fst[u]}, fst[u] = etot; 14 e[++etot] = (edge){v, u, 0, -c, fst[v]}, fst[v] = etot; 15 } 16 17 bool SPFA() 18 { 19 int front = 0, back, u; 20 memset(level, 63, sizeof(level)); 21 level[n + 1] = 0; 22 q[back = 1] = n + 1, inq[n + 1] = true; 23 while(front != back) 24 { 25 u = q[(++front % 1005)]; 26 front %= 1005, inq[u] = false; 27 for(int i = fst[u]; i; i = e[i].nxt) 28 if(e[i].w && level[e[i].v] > level[u] + e[i].c) 29 { 30 level[e[i].v] = level[u] + e[i].c; 31 pth[e[i].v] = i; 32 if(!inq[e[i].v]) 33 { 34 q[(++back % 1005)] = e[i].v; 35 back %= 1005, inq[e[i].v] = true; 36 } 37 } 38 } 39 return level[n + 2] < 1000000000; 40 } 41 42 int Edmond_Karp() 43 { 44 for(int i = pth[n + 2]; i; i = pth[e[i].u]) 45 { 46 --e[i].w, ++e[i ^ 1].w; 47 if(e[i].u == n + 1) use = e[i].v; 48 } 49 return level[n + 2]; 50 } 51 52 int main() 53 { 54 int m, tmp, ans = 0, ptot; 55 scanf("%d%d", &n, &m); 56 for(int i = 1; i <= n; ++i) 57 { 58 scanf("%d", &tmp); 59 addedge(i, n + 2, tmp, 0); 60 } 61 for(int i = 1; i <= n; ++i) 62 for(int j = 1; j <= m; ++j) 63 scanf("%d", &t[i][j]); 64 ptot = n + 2; 65 for(int i = 1; i <= m; ++i) 66 { 67 belong[++ptot] = i, ++fin[i]; 68 for(int j = 1; j <= n; ++j) 69 addedge(ptot, j, 1, t[j][i]); 70 addedge(n + 1, ptot, 1, 0); 71 } 72 while(SPFA()) 73 { 74 ans += Edmond_Karp(); 75 tmp = belong[++ptot] = belong[use], ++fin[tmp]; 76 for(int i = 1; i <= n; ++i) 77 addedge(ptot, i, 1, t[i][tmp] * fin[tmp]); 78 addedge(n + 1, ptot, 1, 0); 79 } 80 printf("%d\n", ans); 81 return 0; 82 }
View Code
转载于:https://www.cnblogs.com/CtrlCV/p/5613857.html
[BZOJ2879] [Noi2012] 美食节 (费用流 动态加边)相关推荐
- [NOI2012]美食节——费用流(带权二分图匹配)+动态加边
题目描述 小M发现,美食节共有n种不同的菜品.每次点餐,每个同学可以选择其中的一个菜品.总共有m个厨师来制作这些菜品.当所有的同学点餐结束后,菜品的制作任务就会分配给每个厨师.然后每个厨师就会同时开始 ...
- BZOJ 2879 美食节(费用流-动态加边)
题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=2879 题意:有n道菜,每道菜需要b[i]份,m个厨师,第j个厨师做第i道菜需要时间a[i ...
- [NOI2012]美食节(费用流)
题目描述 CZ市为了欢迎全国各地的同学,特地举办了一场盛大的美食节.作为一个喜欢尝鲜的美食客,小M自然不愿意错过这场盛宴.他很快就尝遍了美食节所有的美食.然而,尝鲜的欲望是难以满足的.尽管所有的菜品都 ...
- jzoj3302-[集训队互测2013]供电网络【上下界网络流,费用流,动态加边】
正题 题目大意 若干个城市一些城市有一定的电,有些城市需要一定的电.对于第iii个城市购买一个电需要iniin_iini,送出电需要outiout_iouti.当然城市之间也可以相互传输电. 对于 ...
- bzoj2879: [Noi2012]美食节
bzoj2879: [Noi2012]美食节 题意 有n(<=40)道菜,第i道菜被点了pi(∑p<=800)次;有m(<=100)个人,第i个人做第j道菜用时tij(<=10 ...
- Ajax实现瀑布流动态加载网页
瀑布流的动态加载效果是我一直以来觉得最喜欢的效果之一了.最近在工作中遇到了一个情景,当我登录到系统中时,需要向另一个系统发送多次接口查询数据,之后再将这些数据显示到页面上.这就存在了这样一个问题:页面 ...
- [BZOJ2879][Noi2012]美食节(费用流)
Address 洛谷P2050 BZOJ2879 LOJ#2674 Solution 一看发现和 SCOI2007 修车 是一样的. 这里再说一下建图: 把每个厨师拆成 ∑ i = 1 n p i \ ...
- html动态加载图片,javascript实现瀑布流动态加载图片原理
本文实例为大家分享了js瀑布流加载效果,动态加载图片,供大家参考,具体内容如下 鼠标滚动事件,当鼠标滚动到下边,动态加载图片. 1. HTML代码 js实现瀑布流效果-动态加载图片 2. CSS代码 ...
- 5331. 【NOIP2017提高A组模拟8.23】壕游戏 费用流 动态连边
题意:n个点m条边,每条边有一个经过次数限制ci,假设经过了x次,第x次费用为ai*x+bi,有s个终点,要跑k次,问最小总费用多少. 巨鬼畜,连边只按照第一次的连,然后费用流的时候每流一条边然后再连 ...
最新文章
- 某程序员哀叹:连续帮三任女朋友进360,京东等互联网大厂,进去后却都惨遭分手!...
- java基础——java基本运算
- linux 如何查看进程内用户虚拟空间分布
- 如何linux安装apache服务器,Linux中如何安装Apache服务器
- python构建huffman树_python:哈夫曼树,PythonHuffuman
- [C#]使用Costura.Fody将源DLL合并到目标EXE
- 计算机原理阅读,计算机原理与应用作业
- feedburner怎么用_新手RSS订阅使用指南
- Amoeba配置读写分离
- 华为已找到安卓才“替代品”?马云马斯克激辩人工智能未来;微软说:麻将AI系统终获突破;扭亏!中兴通讯上半年净利14.71亿……...
- 加州房价篇 (一) : 了解数据
- 云桌面是什么?云桌面如何运行的?
- C# ABP WebApi与Swagger UI的集成
- 批量关闭公众号推送_微信发大招,长期不读的公众号可“批量关闭”!
- android手机系统对比,国产手机系统哪家强?几大主流手机系统盘点对比
- 量化交易系统用例图(一)
- 网页制作篇(智慧树网站马红老师)-基础知识总结1(标记篇)
- Android 的 LiveReload — jimu Mirror
- java 时区 edt_JAVA TimeZone发行EDT对EST
- Git修改以前某次历史提交注释
热门文章
- 最近让我焦灼的四个问题(有解)
- python 折线图_Python 编程一次画三种图:柱状图、散点图、折线图
- 父页面监听iframe路由变化_前端路由原理
- python中的switch语句_python技巧 switch case语句
- mysql查询mapper.xml_mapper.xml中的mysql查询问题
- Java虚拟机(九)——方法区
- PostgreSQL13逻辑备份pg_dump
- Linux指令设置波特率停止位,linux下的picocom怎么设置停止位,波特率
- mysql两条完全相同的数据_两条完全相同的数据怎么用sql语句删除一条
- android 动态绘制布局,Android代码和绘制曲线中按钮和绘图板的动态布局