【题解】Catering World Finals 2015 上下界费用流
Prelude
传送到Codeforces:0.0
Solution
板子题,在这里贴个板子。
这题面是smg?题面中有说每个点只能经过一次吗?是我瞎了吗?
因为这WA on test 27一个小时,烦死了,浪费时间。
Code
#include <cstring>
#include <algorithm>
#include <cstdio>
#include <queue>
#include <cassert>
using namespace std;
const int MAXN = 1000;
const int MAXM = 100000;
const int INF = 0x3f3f3f3f;
int _w;
int read() {
int x;
_w = scanf( "%d", &x );
return x;
}
namespace MCMF {
struct Edge {
int u, v, c, f, w;
Edge() {}
Edge( int u, int v, int c, int f, int w ):
u(u), v(v), c(c), f(f), w(w) {}
};
int n, m, s, t;
int head[MAXN], nxt[MAXM];
Edge edge[MAXM];
void init( int _n ) {
n = _n, m = 0;
for( int i = 0; i < n; ++i )
head[i] = -1;
}
void adde( int u, int v, int c, int w ) {
edge[m] = Edge(u, v, c, 0, w);
nxt[m] = head[u], head[u] = m++;
edge[m] = Edge(v, u, 0, 0, -w);
nxt[m] = head[v], head[v] = m++;
}
queue<int> q;
int dis[MAXN], inq[MAXN], res[MAXN], from[MAXN];
bool spfa() {
for( int i = 0; i < n; ++i )
dis[i] = INF, inq[i] = 0;
dis[s] = 0, inq[s] = 1, q.push(s), res[s] = INF;
while( !q.empty() ) {
int u = q.front(); q.pop();
inq[u] = 0;
for( int i = head[u]; ~i; i = nxt[i] ) {
const Edge &e = edge[i];
if( e.c > e.f && dis[u] + e.w < dis[e.v] ) {
dis[e.v] = dis[u] + e.w;
from[e.v] = i;
res[e.v] = min( res[u], e.c-e.f );
if( !inq[e.v] )
inq[e.v] = 1, q.push(e.v);
}
}
}
return dis[t] != INF;
}
void augment() {
int f = res[t], u = t;
while( u != s ) {
int i = from[u];
edge[i].f += f;
edge[i^1].f -= f;
u = edge[i].u;
}
}
int solve( int _s, int _t ) {
s = _s, t = _t;
int cost = 0;
while( spfa() ) {
cost += res[t] * dis[t];
augment();
}
return cost;
}
}
int n, k, g[MAXN][MAXN];
int s, t, ss, tt, nid;
int in[MAXN], out[MAXN];
void adde( int u, int v, int l, int r, int w ) {
MCMF::adde(ss, v, l, 0);
MCMF::adde(u, tt, l, 0);
MCMF::adde(u, v, r-l, w);
}
void solve() {
s = nid++, t = nid++, ss = nid++, tt = nid++;
for( int i = 1; i <= n; ++i )
in[i] = nid++, out[i] = nid++;
MCMF::init(nid);
adde(t, s, 0, INF, 0);
adde(s, out[1], 0, k, 0);
for( int i = 2; i <= n; ++i ) {
adde(out[i], t, 0, INF, 0);
adde(in[i], out[i], 1, 1, 0); // 每个点只能经过一次
}
for( int i = 1; i <= n; ++i )
for( int j = i+1; j <= n; ++j )
adde(out[i], in[j], 0, INF, g[i][j]);
printf( "%d\n", MCMF::solve(ss, tt) );
}
int main() {
n = read()+1, k = read();
for( int i = 1; i <= n; ++i )
for( int j = i+1; j <= n; ++j )
g[i][j] = read();
solve();
return 0;
}
【题解】Catering World Finals 2015 上下界费用流的更多相关文章
- 【BZOJ3876】[Ahoi2014]支线剧情 有上下界费用流
[BZOJ3876][Ahoi2014]支线剧情 Description [故事背景] 宅男JYY非常喜欢玩RPG游戏,比如仙剑,轩辕剑等等.不过JYY喜欢的并不是战斗场景,而是类似电视剧一般的充满恩 ...
- 【bzoj2324】[ZJOI2011]营救皮卡丘 最短路-Floyd+有上下界费用流
原文地址:http://www.cnblogs.com/GXZlegend/p/6832504.html 题目描述 皮卡丘被火箭队用邪恶的计谋抢走了!这三个坏家伙还给小智留下了赤果果的挑衅!为了皮卡丘 ...
- 【BZOJ2055】80人环游世界 有上下界费用流
[BZOJ2055]80人环游世界 Description 想必大家都看过成龙大哥的<80天环游世界>,里面的紧张刺激的打斗场面一定给你留下了深刻的印象.现在就有这么 一个 ...
- 【bzoj1927】[Sdoi2010]星际竞速 有上下界费用流
原文地址:http://www.cnblogs.com/GXZlegend/p/6832464.html 题目描述 10年一度的银河系赛车大赛又要开始了.作为全银河最盛大的活动之一,夺得这个项目的冠军 ...
- 【有源汇上下界费用流】BZOJ 3876 [Ahoi2014]支线剧情
题目链接: http://www.lydsy.com:808/JudgeOnline/problem.php?id=3876 题目大意: 给定一张拓扑图(有向无环图),每条边有边权,每次只能从第一个点 ...
- BZOJ 3876: [Ahoi2014]支线剧情 [上下界费用流]
3876: [Ahoi2014]支线剧情 题意:每次只能从1开始,每条边至少经过一次,有边权,求最小花费 裸上下界费用流...每条边下界为1就行了 注意要加上下界*边权 #include <io ...
- BZOJ.1927.[SDOI2010]星际竞速(无源汇上下界费用流SPFA /最小路径覆盖)
题目链接 上下界费用流: /* 每个点i恰好(最少+最多)经过一次->拆点(最多)+限制流量下界(i,i',[1,1],0)(最少) 然后无源汇可行流 不需要源汇. 注: SS只会连i',求SS ...
- BZOJ2324 ZJOI2011营救皮卡丘(floyd+上下界费用流)
虽然不一定每次都是由编号小的点向编号大的走,但一个人摧毁的顺序一定是从编号小的到编号大的.那么在摧毁据点x的过程中,其只能经过编号小于x的点.并且这样一定合法,因为可以控制其他人先去摧毁所经过的点.那 ...
- 【Luogu】P1251餐巾计划(上下界费用流)
题目链接 学了一下上下界费用流,似乎很nb.但是我说得不好,所以这里给出博客链接. 某dalao的博客 然后这道题的解法就是先用上下界费用流的建图方式连早上和晚上之间的那条边,保证当天一定会有r条或以 ...
随机推荐
- Kubernetes探索学习004--深入Kubernetes的Pod
深入研究学习Pod 首先需要认识到Pod才是Kubernetes项目中最小的编排单位原子单位,凡是涉及到调度,网络,存储层面的,基本上都是Pod级别的!官方是用这样的语言来描述的: A Pod is ...
- CocoaPods pod install的时候报错:invalid byte sequence in UTF-8 (ArgumentError)解决办法
CocoaPods pod install的时候报错:invalid byte sequence in UTF-8 (ArgumentError)解决办法: 基本可以确定是Podfile中的内容编码有 ...
- 关于手机端h5上传图片配合exif.min.js,processImg.js的使用
首先这里有个new FileReader()的概念,这是h5新增的,用来把文件读入内存,并且读取文件中的数据.FileReader接口提供了一个异步API,使用该API可以在浏览器主线程中异步访问文件 ...
- LIFI热火下的VLC基本链路、标准及发展问题
和白炽及荧光灯相比,白光发光二极管(LED)具有寿命长.光效高.功耗低.无辐射.安全性好.可靠性高等特点,被称为"绿色照明"并得到迅猛发展.白光LED在未来市场极具竞争力.世界范围 ...
- Redux和React-Redux的实现(三):中间件的原理和applyMiddleware、Thunk的实现
现在我们的Redux和React-Redux已经基本实现了,在Redux中,触发一个action,reducer立即就能算出相应的state,如果我要过一会才让reducer计算state呢怎么办?也 ...
- Daily Srum 10.21
到目前为止,我们组处在学习阶段,很多知识点都还不太清楚,所以现在我们还在看相关书籍和博客,任务. 而我们此间主要是在阅读一些材料: 陈谋一直在看学长的代码,其中C#的很多方式我都不太明白(尽管和Jav ...
- cnblogs.com用户体验
一.是否提供了良好的体验给用户(同时提供价值)? 首先我觉得博客园给我们这些用户提供了良好的用户体验,博客园提供了一个纯净的技术交流空间,在这里我们可以找到几乎所有与IT技术有关的博文,而且可以在这里 ...
- Chapter 3 软件项目管理
软件项目具有产品的不可见性.项目的高度不确定性.软件过程的多变化性.软件人员的高流动性的显著特征.有效的软件项目管理集中于人员.产品.过程和项目四个方面.软件项目的生命周期有项目启动.项目规划.项目实 ...
- 文件上传到tomcat服务器 commons-fileupload的详细介绍与使用
三个类:DiskFileUpload.FileItem和FileUploadException.这三个类全部位于org.apache.commons.fileupload包中. 首先需要说明一下for ...
- boolean类型的按位或||和|的区别
boolean类型既可以使用&&和||做逻辑运算,也可以使用&和|做逻辑运算,但前者是经过优化的(执行短路运算),后者未优化. 以下代码验证: 逻辑或|| public cla ...