POJ 2455 Secret Milking Machine 【二分】+【最大流】
<题目链接>
题目大意:
FJ有N块地,这些地之间有P条双向路,每条路的都有固定的长度l。现在要你找出从第1块地到第n块地的T条不同路径,每条路径上的路段不能与先前的路径重复,问这些路径中的最长路段的最小值是多少。
解题分析:
最小的最大值问题,依然需要用二分答案,枚举出该最大路段的长度,然后将所有小于等于这个值得路段加入网络,将这些路段的容量置为1。因为是无向图,所以正、反向弧的容量都置为1,之后跑一遍最大流,再根据最大流和T的大小关系来判断。
- #include <cstdio>
- #include <cstring>
- #include <queue>
- #include <algorithm>
- using namespace std;
- #define INF 0x3f3f3f3f
- #define mem(a,b) memset(a,b,sizeof(a))
- const int N=;
- struct Edge{
- int u,v,c;
- }edge[N*N*];
- struct Segment{
- int a,b,len;
- }seg[N*N];
- int d[N],cur[N];
- int head[N],next[N*N*];
- int n,m,k,maxlen,minlen,cnt;
- void addedge(int u,int v,int w){
- edge[cnt].u=u;edge[cnt].v=v,edge[cnt].c=w;
- next[cnt]=head[u],head[u]=cnt++;
- edge[cnt].u=v;edge[cnt].v=u,edge[cnt].c=w;
- next[cnt]=head[v],head[v]=cnt++;
- }
- int bfs(int s,int t){
- queue<int> q;
- mem(d,);
- d[s]=;
- q.push(s);
- while(!q.empty()){
- int x=q.front();q.pop();
- for(int i=head[x];i!=-;i=next[i]){
- if(edge[i].c> && !d[edge[i].v]){
- d[edge[i].v]=d[x]+;
- q.push(edge[i].v);
- }
- }
- }
- return d[t];
- }
- int dfs(int x,int a){
- if(x==n || a==)return a;
- int t,f,flow=;
- for(int& i=cur[x];i!=-;i=next[i]){
- if(d[x]+==d[edge[i].v] && (f=dfs(edge[i].v,min(a,edge[i].c)))>){
- edge[i].c-=f;
- edge[i^].c+=f;
- flow+=f;
- a-=f;
- if(!a)break;
- }
- }
- return flow;
- }
- int dinic(int s,int t,int limit){
- int i,ret=;
- while(bfs(s,t)){
- for(i=;i<=n;i++)cur[i]=head[i];
- ret+=dfs(s,INF);
- }
- return ret;
- }
- int binary_solve(){
- int low=minlen,high=maxlen;
- while(low<high){ //这个二分答案部分对格式还是有点疑惑
- int mid=(low+high)>>;
- cnt=;mem(head,-); //init()
- for(int i=;i<m;i++) //加入所有满足要求的边
- if(seg[i].len<=mid)
- addedge(seg[i].a,seg[i].b,);
- int t=dinic(,n,mid);
- if(t<k)low=mid+;
- else high=mid;
- }
- return low;
- }
- int main(){
- while(~scanf("%d%d%d",&n,&m,&k)){
- maxlen=-INF;minlen=INF;
- for(int i=;i<m;i++){
- scanf("%d%d%d",&seg[i].a,&seg[i].b,&seg[i].len);
- maxlen=max(maxlen,seg[i].len);
- minlen=min(minlen,seg[i].len);
- }
- printf("%d\n",binary_solve());
- }
- return ;
- }
2018-11-24
POJ 2455 Secret Milking Machine 【二分】+【最大流】的更多相关文章
- POJ 2455 Secret Milking Machine (二分 + 最大流)
题目大意: 给出一张无向图,找出T条从1..N的路径,互不重复,求走过的所有边中的最大值最小是多少. 算法讨论: 首先最大值最小就提醒我们用二分,每次二分一个最大值,然后重新构图,把那些边权符合要求的 ...
- poj 2455 Secret Milking Machine 二分+最大流 sap
题目:p条路,连接n个节点,现在需要从节点1到节点n,不重复走过一条路且走t次,最小化这t次中连接两个节点最长的那条路的值. 分析:二分答案,对于<=二分的值的边建边,跑一次最大流即可. #in ...
- POJ 2455 Secret Milking Machine(最大流+二分)
Description Farmer John is constructing a new milking machine and wishes to keep it secret as long a ...
- POJ 2455 Secret Milking Machine (二分+无向图最大流)
[题意]n个点的一个无向图,在保证存在T条从1到n的不重复路径(任意一条边都不能重复)的前提下,要使得这t条路上经过的最长路径最短. 之所以把"经过的最长路径最短"划个重点是因为前 ...
- POJ 2455 Secret Milking Machine(搜索-二分,网络流-最大流)
Secret Milking Machine Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 9658 Accepted: ...
- POJ 2455 - Secret Milking Machine
原题地址:http://poj.org/problem?id=2455 题目大意:给出一个N个点的无向图,中间有P条边,要求找出从1到n的T条通路,满足它们之间没有公共边,并使得这些通路中经过的最长的 ...
- POJ 2112 Optimal Milking(二分+最大流)
http://poj.org/problem?id=2112 题意: 现在有K台挤奶器和C头奶牛,奶牛和挤奶器之间有距离,每台挤奶器每天最多为M头奶挤奶,现在要安排路程,使得C头奶牛所走的路程中的最大 ...
- POJ - 2112 Optimal Milking (dijkstra + 二分 + 最大流Dinic)
(点击此处查看原题) 题目分析 题意:在一个农场中有k台挤奶器和c只奶牛,每个挤奶器最多只能为m只奶牛挤奶,每个挤奶器和奶牛都视为一个点,将编号1~k记为挤奶器的位置,编号k+1~k+c记为奶牛的位置 ...
- POJ 2112 Optimal Milking (Floyd+二分+最大流)
[题意]有K台挤奶机,C头奶牛,在奶牛和机器间有一组长度不同的路,每台机器每天最多能为M头奶牛挤奶.现在要寻找一个方案,安排每头奶牛到某台机器挤奶,使得C头奶牛中走过的路径长度的和的最大值最小. 挺好 ...
随机推荐
- 姿势摆好,一招学会android的布局优化!
作为android应用来讲,无论应用本身多么美观,功能多么强大,内容多么丰富.但如果App本身打开界面缓慢超过手机16ms刷新一次页面的时间,就会产生卡顿.用户体验都会变得极差,导致用户量减少.所以我 ...
- 使用Eclipse进行Makefile项目
最近在MCU on Eclipse网站上看到Erich Styger所写的一篇有关在Eclipse中使用Makefile创建项目的文章,文章讲解清晰明了非常不错,所以呢没人将其翻译过来供各位同仁参考. ...
- Windows下Oracle 11g创建数据库
以前开发的时候用得比较多的是mysql和sql server,oracle用的比较少,用起来比较生疏,mysql和sql server用起来比较类似,就oracle的使用方式和他们不同,oracle在 ...
- npm安装依赖包 --save-dev 和 --save; package.json的devDependencies和dependencies 的区别!
以前一直在纠结一个npm安装的包依赖管理的问题.是这样的: 我们在使用npm install 安装模块或插件的时候,有两种命令把他们写入到 package.json 文件里面去,他们是:--save- ...
- IE11总是有缓存的问题
F12,里面选择网络,始终从服务器刷新..
- laravel 容器注入的坑
今天遍历添加数据时遇到个坑,哪位大神知道什么原因?? 起初的代码是这样的:(部分) public function addActive(Request $request, Activenorms $a ...
- Allegro PCB Design GXL (legacy) 设置十字大光标
Allegro PCB Design GXL (legacy) version 16.6-2015 1.菜单:Setup > User Preferences... 2.User Prefere ...
- JS实现继承的几种方式(转)
转自:幻天芒的博客 前言 JS作为面向对象的弱类型语言,继承也是其非常强大的特性之一.那么如何在JS中实现继承呢?让我们拭目以待. JS继承的实现方式 既然要实现继承,那么首先我们得有一个父类,代码如 ...
- js cookie 工具
var CookieUtil = { get: function(name) { var cookieName = encodeURIComponent(name) + "=", ...
- 010-Python-socket编程
客户端/服务器的架构 物理层:网卡,光缆,双绞线 数据链路层:包含源mac地址和目标的mac地址,通过广播通讯 网络层:跑的IP协议,IP地址可以定义到一个子网:通过ARP协议可以解析为mac地址: ...