Secret Milking Machine POJ - 2455 网络流(Dinic算法---广搜判断+深搜增广)+时间优化+二分
题意:
第一行输入N M C ,表示从1到N有M条无向边,现在要从1走到N 走C次完全不同的路径,求最长边的最小值。下面M行是从a点到b点的距离。
建图:
题上说从两点之间可以有多条边,问的是从1~N的C种走法,所走路径上的最大边最小可以是多少,所以我们用结构体来储存点的距离,用二分搜索中的mid来假设成最大边的值,那么其他边都要小于等于它,然后根据mid建图,两点之间的边数作为容量网络的边权,也就是两点间的容量,(Dinic跑一遍)求出一个最大流,看它与C的关系,如果C大于它,说明mid太小,反之mid太大。
关于Dinic 和 优化·
首先通过广搜判断是否存在增广路,然后用深搜对地图进行操作,求最大流。深搜的时候有两个形参,一个是点的编号,另一个是由上一个点流过来的流量(具体见注释)
优化是先通过广搜的标记数组book[ ]的值,初始化为-1,大于等于0代表已经走过,不过标记的时候是
book[i]=book[k]+1(k走到 i),用于深搜的时候判断for循环中的顶点是否可走。在深搜的时候如果一个点没有网络流,就标记为-2或更小,下一次就不再在这个点搜了。(不优化则超时)
#include<queue>
#include<stdio.h>
#include<string.h>
using namespace std;
struct
{
int u,v,w;
}mp[40100];
int e[220][221],n,m,sign[220][220],mid,inf=0x3f3f3f3f;
int book[220];
int bfs()
{
memset(book,-1,sizeof(book));
memset(sign,0,sizeof(sign));
book[1]=0;
queue<int>q;
q.push(1);
while(!q.empty())
{
int k=q.front();
q.pop();
for(int i=1;i<=n;i++)
{
if(book[i]<0&&e[k][i]>0)//没有走过并且可以走
{
book[i]=book[k]+1;//从 k 点走过来 k->i
q.push(i);
}
}
}
if(book[n]>=0) return 1;
return 0;
}
void build()
{
memset(e,0,sizeof(e));
for(int i=0;i<m;i++)
if(mp[i].w<=mid)
{
e[mp[i].v][mp[i].u]++;
e[mp[i].u][mp[i].v]++;
}
}
int dfs(int v,int sum)
{
int t,s,i,use=0;
if(v==n)//找到终点 s=sum
return sum;
for(int i=1;i<=n;i++)
{
if(e[v][i]>0&&book[i]==book[v]+1)//v->i
{
t=dfs(i,min(sum,e[v][i]));//路径上最小的流
use+=t;//回溯时加减
e[v][i]-=t;
e[i][v]+=t;
sum-=t;
}
if(sum<=0)//如果sum小于零 不再递归
break;
}
if(!use)book[v]=-2;// 路径以后不再走 节点中没有网络流
return use;//返回最大流相当于s-sum
}
int main()
{
int c;
while(~scanf("%d%d%d",&n,&m,&c))
{
int t1,t2,t3,l=inf,r=-1;
for(int i=0;i<m;i++)
{
scanf("%d%d%d",&mp[i].u,&mp[i].v,&mp[i].w);
if(l>mp[i].w)//超时
l=mp[i].w;
if(r<mp[i].w)
r=mp[i].w;
}
while(l<r)
{
mid=(l+r)/2;
build();
int ans=0;
while(bfs()) ans+=dfs(1,inf);
if(ans>=c)
r=mid;
else
l=mid+1;
}
printf("%d\n",r);
}
return 0;
}
Secret Milking Machine POJ - 2455 网络流(Dinic算法---广搜判断+深搜增广)+时间优化+二分的更多相关文章
- POJ 3281 网络流dinic算法
B - Dining Time Limit:2000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u Submit S ...
- POJ 3281 [网络流dinic算法模板]
题意: 农场主有f种食物,d种饮料,n头牛. 接下来的n行每行第一个数代表第i头牛喜欢吃的食物数量,和第i头牛喜欢喝的饮料数目. 接下来分别是喜欢的食物和饮料的编号. 求解:农场主最多能保证几头牛同时 ...
- POJ 2455 Secret Milking Machine(搜索-二分,网络流-最大流)
Secret Milking Machine Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 9658 Accepted: ...
- 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 网络流 基础题 二分+网络流 dicnic 以及 sap算法
Secret Milking Machine Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 8189 Accepted: ...
- 【bzoj1733】[Usaco2005 feb]Secret Milking Machine 神秘的挤奶机 二分+网络流最大流
题目描述 Farmer John is constructing a new milking machine and wishes to keep it secret as long as possi ...
- [bzoj1733][Usaco2005 feb]Secret Milking Machine 神秘的挤奶机_网络流
[Usaco2005 feb]Secret Milking Machine 神秘的挤奶机 题目大意:约翰正在制造一台新型的挤奶机,但他不希望别人知道.他希望尽可能久地隐藏这个秘密.他把挤奶机藏在他的农 ...
- BZOJ 1733: [Usaco2005 feb]Secret Milking Machine 神秘的挤奶机 网络流 + 二分答案
Description Farmer John is constructing a new milking machine and wishes to keep it secret as long a ...
- POJ2455 Secret Milking Machine
Secret Milking Machine Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 12324 Accepted ...
随机推荐
- 虚拟机+server03系统+sql的安装
教程: 首先安装虚拟机 然后安装server系统 最后完成sql的安装 https://download.pchome.net/system/sysenhance/detail-4673.html 虚 ...
- 做直播能有多赚钱,Python告诉你
前面我们介绍了APP爬虫环境的搭建和mitmproxy工具的简单使用,这次我们要来一个简单的APP爬虫,尝试一下APP爬虫的简单实用,顺便让我们看看喜马拉雅上的主播到底有多赚钱. APP爬虫一般分为两 ...
- Ambari2.7.4+HDP3.1.4安装 Centos7离线安装
一. Ambari等简单介绍 1.1Ambari Ambari是一种基于Web的工具,支持Apache Hadoop集群的创建 .管理和监控. Ambari已支持大多数Hadoop组件,包括HDFS. ...
- C#小游戏—钢铁侠VS太空侵略者
身为漫威迷,最近又把<钢铁侠>和<复仇者联盟>系列又重温了一遍,真的是印证了那句话:“读书百遍,其意自现”.看电影一个道理,每看一遍,都有不懂的感受~ 不知道大伙是不是也有同样 ...
- 东南大学RM装甲板识别算法详解
rm中,装甲板的识别在比赛中可谓是最基础的算法.而在各个开源框架中,该算法也可以说最为成熟.出于学习目的,之后将对比多个高校或网络代码(),尝试学习各个rm装甲板识别算法的优点和流程. 这次先是东南大 ...
- javascript入门进阶(一)
javascript 入门进阶 这里主要讲解一下在入门阶段很难注意的一些知识点,不一定有用.但是会了总比不会强. 1.HTML为<script>标签准备的6个属性: -async:可选.表 ...
- vnstat 流量统计 并附带一个小 php 查看流量的页面
安装apt-get install vnstat 配置到自动启动update-rc.d vnstat enable 启动/etc/init.d/vnstat start vnstat基本使用命令 vn ...
- 设计模式之委派模式,大名鼎鼎的Spring都在用
什么是委派模式 虽然说委派模式不属于Gof23中设计模式,但这并不影响它成为一种经典的设计模式. "委派"字面意思就是指派一件事情给某人.类比到生活中的场景,比如项目leader指 ...
- 数据结构 5 哈希表/HashMap 、自动扩容、多线程会出现的问题
上一节,我们已经介绍了最重要的B树以及B+树,使用的情况以及区别的内容.当然,本节课,我们将学习重要的一个数据结构.哈希表 哈希表 哈希也常被称作是散列表,为什么要这么称呼呢,散列.散列.其元素分布较 ...
- C语言程序设计(六) 循环控制结构
第六章 循环控制结构 循环结构:需要重复执行的操作 被重复执行的语句序列称为循环体 计数控制的循环 条件控制的循环 当型循环结构 直到型循环结构 for while do-while while(循环 ...