【bzoj2625】[Neerc2009]Inspection 有上下界最小流
题目描述
Your team has to inspect each slope of the ski resort. Ski lifts on this resort are not open yet, but you have a helicopter. In one fiight the helicopter can drop one person into any point of the resort. From the drop off point the person can ski down the slopes, inspecting each slope as they ski. It is fine to inspect the same slope multiple times, but you have to minimize the usage of the helicopter. So, you have to figure out how to inspect all the slopes with the fewest number of helicopter flights.
输入
输出
样例输入
8
1 3
1 7
2 4 5
1 8
1 8
0
2 6 5
0
样例输出
4
题解
有上下界最小流
题目要求可以从任意点出发到任意点停止,每条边至少经过一次。这显然是最小流问题。
连边S->每个点、每个点->T、T->S、原图中的边,容量为inf;对于每个点x如果入度大于0则连SS->x,容量为ind[x],否则连x->TT,容量为-ind[x]。
跑SS->TT最大流,然后把T->S、SS->x、x->TT边删除,跑T->S最大流,两次答案相减即为答案。
- #include <cstdio>
- #include <cstring>
- #include <queue>
- #define N 110
- #define M 20010
- using namespace std;
- const int inf = 1 << 30;
- queue<int> q;
- int head[N] , to[M] , val[M] , next[M] , cnt = 1 , s , t , dis[N] , ind[N];
- void add(int x , int y , int z)
- {
- to[++cnt] = y , val[cnt] = z , next[cnt] = head[x] , head[x] = cnt;
- to[++cnt] = x , val[cnt] = 0 , next[cnt] = head[y] , head[y] = cnt;
- }
- bool bfs()
- {
- int x , i;
- memset(dis , 0 , sizeof(dis));
- while(!q.empty()) q.pop();
- dis[s] = 1 , q.push(s);
- while(!q.empty())
- {
- x = q.front() , q.pop();
- for(i = head[x] ; i ; i = next[i])
- {
- if(val[i] && !dis[to[i]])
- {
- dis[to[i]] = dis[x] + 1;
- if(to[i] == t) return 1;
- q.push(to[i]);
- }
- }
- }
- return 0;
- }
- int dinic(int x , int low)
- {
- if(x == t) return low;
- int temp = low , i , k;
- for(i = head[x] ; i ; i = next[i])
- {
- if(val[i] && dis[to[i]] == dis[x] + 1)
- {
- k = dinic(to[i] , min(temp , val[i]));
- if(!k) dis[to[i]] = 0;
- val[i] -= k , val[i ^ 1] += k;
- if(!(temp -= k)) break;
- }
- }
- return low - temp;
- }
- int main()
- {
- int n , i , b , e , x , y , ans = 0;
- scanf("%d" , &n) , b = 0 , e = n + 1 , s = n + 2 , t = n + 3;
- add(e , b , inf);
- for(i = 1 ; i <= n ; i ++ )
- {
- scanf("%d" , &y);
- while(y -- ) scanf("%d" , &x) , add(i , x , inf) , ind[i] -- , ind[x] ++ ;
- }
- for(i = 1 ; i <= n ; i ++ )
- {
- add(b , i , inf) , add(i , e , inf);
- if(ind[i] > 0) add(s , i , ind[i]);
- else add(i , t , -ind[i]);
- }
- while(bfs()) dinic(s , inf);
- ans = val[3] , val[2] = val[3] = 0;
- for(i = head[s] ; i ; i = next[i]) val[i] = val[i ^ 1] = 0;
- for(i = head[t] ; i ; i = next[i]) val[i] = val[i ^ 1] = 0;
- s = e , t = b;
- while(bfs()) ans -= dinic(s , inf);
- printf("%d\n" , ans);
- return 0;
- }
【bzoj2625】[Neerc2009]Inspection 有上下界最小流的更多相关文章
- sgu 176 Flow construction(有源汇的上下界最小流)
[题目链接] http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=11025 [模型] 有源汇点的上下界最小流.即既满足上下界又满足 ...
- BZOJ_2502_清理雪道_有源汇上下界最小流
BZOJ_2502_清理雪道_有源汇上下界最小流 Description 滑雪场坐落在FJ省西北部的若干座山上. 从空中鸟瞰,滑雪场可以看作一个有向无环图,每条弧代表一个斜坡(即雪道), ...
- 【Loj117】有源汇上下界最小流(网络流)
[Loj117]有源汇上下界最小流(网络流) 题面 Loj 题解 还是模板题. #include<iostream> #include<cstdio> #include< ...
- SGU 176 Flow construction (有源有汇有上下界最小流)
题意:给定 n 个点,m 条有向边,如果有向边的标号是1的话,就表示该边的上界下界都为容量 ,如果有向边的标号为0的哈,表示该边的下界为0,上界为容量 ,现在问,从 1 到 n 的最小流是多少,并输出 ...
- loj #117. 有源汇有上下界最小流
题目链接 有源汇有上下界最小流,->上下界网络流 注意细节,边数组也要算上后加到SS,TT边. #include<cstdio> #include<algorithm> ...
- LOJ.117.[模板]有源汇有上下界最小流(Dinic)
题目链接 有源汇有上下界最小流 Sol1. 首先和无源汇网络流一样建图,求SS->TT最大流: 然后连边(T->S,[0,INF]),再求一遍SS->TT最大流,答案为新添加边的流量 ...
- BZOJ1458:士兵占领(有上下界最小流)
Description 有一个M * N的棋盘,有的格子是障碍.现在你要选择一些格子来放置一些士兵,一个格子里最多可以放置一个士兵,障碍格里不能放置士兵.我们称这些士兵占领了整个棋盘当满足第i行至少放 ...
- HDU 3157 Crazy Circuits (有源汇上下界最小流)
题意:一个电路板,上面有N个接线柱(标号1~N) 还有两个电源接线柱 + - 然后是 给出M个部件正负极的接线柱和最小电流,求一个可以让所有部件正常工作的总电流. 析:这是一个有源汇有上下界的 ...
- hdu3157有源汇上下界最小流
题意:有源汇上下界最小流裸题,主要就是输入要用字符串的问题 #include<bits/stdc++.h> #define fi first #define se second #defi ...
随机推荐
- 如何在Netweaver SE16里直接查看某数据库行记录
有的数据库表字段类型为RAWSTRING, 包含的是XML的二进制内容,无法直接在SE16里显示. 如果确实想看其内容,怎么办?在下面SE16页面的命令提示栏输入命令/h, 回车进入调试模式.然后双击 ...
- Linux中根据访问日志统计访问量最高的前N个IP
前段时间面试中被问到如上问题,日常不怎么注意积累,以此谨记. 访问IP 页面[nxuser@im440-zh test]$ vi log 135.252.172.181 page1 136.252.1 ...
- UVA 1153 Keep the Customer Satisfied 顾客是上帝(贪心)
因为每增加一个订单,时间是会增加的,所以先按截止时间d排序, 这样的话无论是删除一个订单,或者增加订单,都不会影响已经选好的订单. 然后维护一个已经选好的订单的大根堆(优先队列),如果当前无法选择的话 ...
- [论文理解] CornerNet: Detecting Objects as Paired Keypoints
[论文理解] CornerNet: Detecting Objects as Paired Keypoints 简介 首先这是一篇anchor free的文章,看了之后觉得方法挺好的,预测左上角和右下 ...
- python_89_configparser模块
用于生成和修改常见配置文档,当前模块的名称在 python 3.x 版本中变更为 configparser.在python2.x版本中为ConfigPsresr 来看一个好多软件的常见文档格式如下 [ ...
- PropertyConfigurer.java
package util; import java.util.Properties; import org.springframework.beans.BeansException; import o ...
- Java压缩字符串工具类
StringCompressUtils.java package javax.utils; import java.io.ByteArrayInputStream; import java.io.By ...
- kubernetes-核心概念及创建应用(六)
kubernetes是什么: •Kubernetes是Google在2014年开源的一个容器集群管理系统,Kubernetes简称K8S.•K8S用于容器化应用程序的部署,扩展和管理.•K8S提供了容 ...
- centos7-vsftpd文件服务器
FTP简介: 文件传输协议(File Transfer Protocol,FTP),基于该协议FTP客户端与服务端可以实现共享文件.上传文件.下载文件. FTP 基于TCP协议生成一个虚拟的连接,主要 ...
- if...else...这段代码打印结果,并简述其理由
var age = 20; if (age >= 6) { console.log('teenager'); } else if (age >= 18) { console.log('ad ...