有源汇有上下界的最小可行流。

YY一下建图应该很好搞吧(?

就是对于每个雪道都是[1,inf]然后源点到所有点都是[0,inf]所有点到汇点都是[0,inf]

这样的话跑一个有源汇上下界最小可行流就可以了

有关于这个可以看liu_runda神犇的介绍 非常直观易懂

最开始先建超级源汇 跑可行流得到一个基础流量 然后反向在残余网络上跑最大流减去即可

注意最后的时候是需要反向在残余网络上跑的 不要忘记交换源汇

代码。

//Love and Freedom.
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<queue>
#define inf 20021225
#define ll long long
#define N 200
#define M 40000
using namespace std; struct edge{int lt,to,f;}e[M<<];
int cnt=,in[N],dep[N],s,t,ss,tt;
queue<int> q;
void add(int x,int y,int f)
{
e[++cnt].to = y; e[cnt].lt = in[x]; in[x] = cnt; e[cnt].f = f;
e[++cnt].to = x; e[cnt].lt = in[y]; in[y] = cnt; e[cnt].f = ;
}
bool bfs()
{
while(!q.empty()) q.pop();
q.push(s); memset(dep,,sizeof(dep)); dep[s] = ;
while(!q.empty())
{
int x = q.front(); q.pop();
for(int i=in[x];i;i=e[i].lt)
{
int y = e[i].to; if(dep[y] || !e[i].f) continue;
dep[y] = dep[x]+; q.push(y);
if(y==t) return ;
}
}
return ;
}
int dfs(int x,int f)
{
if(!f || x==t) return f;
int flow = f;
for(int i=in[x];i;i=e[i].lt)
{
int y = e[i].to;
if(dep[y] == dep[x]+ && e[i].f && flow)
{
int cur = dfs(y,min(flow,e[i].f));
e[i^].f += cur; e[i].f -= cur;
flow -= cur; if(!flow) return f;
}
}
dep[x] = -; return f-flow;
}
int dinic()
{
int ans = ;
while(bfs()) ans+=dfs(s,inf);
return ans;
}
int most[M],f[N],n;
void del(int x)
{
for(int i=in[x];i;i=e[i].lt)
e[i].f = e[i^].f = ;
}
int main()
{
s = N-; t = s+; ss = t+; tt = ss+;
scanf("%d",&n);
for(int x=;x<=n;x++)
{
int i,y; scanf("%d",&i);
while(i--)
{
scanf("%d",&y); f[y]++; f[x]--;
add(x,y,inf);
}
}
for(int x=;x<=n;x++){add(s,x,inf); add(x,t,inf);}
for(int i=;i<=n;i++)
{
if(f[i]<) add(i,tt,-f[i]);
else add(ss,i,f[i]);
}
add(t,s,inf); int tmps = s,tmpt = t;
s = ss; t = tt; int flow = dinic();
flow = e[cnt].f; e[cnt].f = e[cnt-].f = ;
del(ss); del(tt); s = tmpt,t = tmps;
printf("%d\n",flow-dinic());
return ;
}

洛谷4843 BZOJ2502 清理雪道的更多相关文章

  1. [BZOJ2502]清理雪道

    [BZOJ2502]清理雪道 试题描述 滑雪场坐落在FJ省西北部的若干座山上. 从空中鸟瞰,滑雪场可以看作一个有向无环图,每条弧代表一个斜坡(即雪道),弧的方向代表斜坡下降的方向. 你的团队负责每周定 ...

  2. BZOJ2502:清理雪道(有上下界最小流)

    Description        滑雪场坐落在FJ省西北部的若干座山上. 从空中鸟瞰,滑雪场可以看作一个有向无环图,每条弧代表一个斜坡(即雪道),弧的方向代表斜坡下降的方向. 你的团队负责每周定时 ...

  3. [BZOJ2502]清理雪道 有上下界网络流(最小流)

    2502: 清理雪道 Time Limit: 10 Sec  Memory Limit: 128 MB Description        滑雪场坐落在FJ省西北部的若干座山上. 从空中鸟瞰,滑雪场 ...

  4. [BZOJ2502]清理雪道解题报告|带下界的最小流

    滑雪场坐落在FJ省西北部的若干座山上. 从空中鸟瞰,滑雪场可以看作一个有向无环图,每条弧代表一个斜坡(即雪道),弧的方向代表斜坡下降的方向. 你的团队负责每周定时清理雪道.你们拥有一架直升飞机,每次飞 ...

  5. 【上下界网络流】bzoj2502: 清理雪道

    模型:无源汇有上下界可行流 LJN:模板题吧 Description        滑雪场坐落在FJ省西北部的若干座山上. 从空中鸟瞰,滑雪场可以看作一个有向无环图,每条弧代表一个斜坡(即雪道),弧的 ...

  6. 洛谷2943 [USACO09MAR]清理Cleaning Up——转变枚举内容的dp

    题目:https://www.luogu.org/problemnew/show/P2943 一下想到n^2.然后不会了. 看过TJ之后似乎有了新的认识. n^2的冗余部分在于当后面那部分的种类数一样 ...

  7. bzoj2502: 清理雪道(有源汇有上下界最小流)

    传送门 别说话,自己看,我不会->这里 我这里用的建图方法是先跑一次最大流,连上$(t,s,inf)$之后再跑一遍,然后答案就是之前连的那条边的反向边的流量 据说还有种方法是连上$(t,s,in ...

  8. bzoj2502清理雪道

    传送门 好题啊,由于每个点既可以进,也可以出,就可以新建一个源点和汇点,对于每个点都连边,然后就是最小流板子了. 代码: #include<cstdio> #include<iost ...

  9. [bzoj2502]清理雪道[上下界网络流]

    bzoj状态里有两种,一种时间是个位数,一种是四位数,我就是四位数的那种,,,估计都是看了hzwer.. #include <bits/stdc++.h> #define INF 0x3f ...

随机推荐

  1. luogu P1449 后缀表达式 x

    题目描述 所谓后缀表达式是指这样的一个表达式:式中不再引用括号,运算符号放在两个运算对象之后,所有计算按运算符号出现的顺序,严格地由左而右新进行(不用考虑运算符的优先级). 如:3*(5–2)+7对应 ...

  2. Milking Grid poj2185

    Milking Grid POJ - 2185 时限: 3000MS   内存: 65536KB   64位IO格式: %I64d & %I64u 提交 状态 已开启划词翻译 问题描述 Eve ...

  3. sqlserver安装-1

    原文地址: https://blog.csdn.net/qq_41432123/article/details/79053486 下载:(免费使用安装dev版) ed2k://|file|cn_sql ...

  4. Yii 1.1 常规框架部署和配置

    <?php //index.php //入口文件配置操作 // change the following paths if necessary $yii=dirname(__FILE__).'/ ...

  5. PHP7.2中AES加密解密方法mcrypt_module_open()替换方案 Function mcrypt_get_block_size() is deprecated

    直接粘代码,该类是基于微信公众号消息加密解密所提供的PHP DEMO改造而来,目前使用于彬彬大学APP接口token校验中. php的mcrypt 扩展已经过时了大约10年,并且用起来很复杂.因此它被 ...

  6. 【转载】Spring boot学习记录(一)-入门篇

    前言:本系列文章非本人原创,转自:http://tengj.top/2017/04/24/springboot0/ 正文 首先声明,Spring Boot不是一门新技术.从本质上来说,Spring B ...

  7. 2019/10/27 TZOJ

    1001 Gaussian Prime http://www.tzcoder.cn/acmhome/problemdetail.do?&method=showdetail&id=379 ...

  8. Codeforces Round #410 (Div. 2)B. Mike and strings(暴力)

    传送门 Description Mike has n strings s1, s2, ..., sn each consisting of lowercase English letters. In ...

  9. GB/T2659-2000《世界各国和地区名称代码》

    代码 代码名称 004 阿富汗 008 阿尔巴尼亚 012 阿尔及利亚 016 美属萨摩亚 020 安道尔 024 安哥拉 660 安圭拉 010 南极洲 028 安提瓜和巴布达 032 阿根廷 05 ...

  10. Django CORS跨域资源共享

    1,什么是CORS ​ 允许浏览器向跨源(协议 + 域名 + 端口)服务器发出XMLHttpRequest请求,从而克服了AJAX只能同源使用的限制 2,特点 ​ 1,浏览器自动完成(在请求头中加入特 ...