题意:

第一行输入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算法---广搜判断+深搜增广)+时间优化+二分的更多相关文章

  1. POJ 3281 网络流dinic算法

    B - Dining Time Limit:2000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u Submit S ...

  2. POJ 3281 [网络流dinic算法模板]

    题意: 农场主有f种食物,d种饮料,n头牛. 接下来的n行每行第一个数代表第i头牛喜欢吃的食物数量,和第i头牛喜欢喝的饮料数目. 接下来分别是喜欢的食物和饮料的编号. 求解:农场主最多能保证几头牛同时 ...

  3. POJ 2455 Secret Milking Machine(搜索-二分,网络流-最大流)

    Secret Milking Machine Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 9658   Accepted: ...

  4. POJ 2455 Secret Milking Machine(最大流+二分)

    Description Farmer John is constructing a new milking machine and wishes to keep it secret as long a ...

  5. POJ 2455 网络流 基础题 二分+网络流 dicnic 以及 sap算法

    Secret Milking Machine Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8189   Accepted: ...

  6. 【bzoj1733】[Usaco2005 feb]Secret Milking Machine 神秘的挤奶机 二分+网络流最大流

    题目描述 Farmer John is constructing a new milking machine and wishes to keep it secret as long as possi ...

  7. [bzoj1733][Usaco2005 feb]Secret Milking Machine 神秘的挤奶机_网络流

    [Usaco2005 feb]Secret Milking Machine 神秘的挤奶机 题目大意:约翰正在制造一台新型的挤奶机,但他不希望别人知道.他希望尽可能久地隐藏这个秘密.他把挤奶机藏在他的农 ...

  8. 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 ...

  9. POJ2455 Secret Milking Machine

    Secret Milking Machine Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 12324   Accepted ...

随机推荐

  1. ubuntu 18.04门等字不正常

    sudo vim /etc/fonts/conf.d/64-language-selector-prefer.conf 该文件配置了 Noto Sans CJK 的优先级.i进入编辑后,可以看到,JP ...

  2. idea通过maven打jar包不成功或无法加载主类或打成功也找不到jar包

    这个问题纠结了我一天,在网上也搜了一些方法,现在把我自己的处理过程记录一下,以方便遇到此类问题的小伙伴参考: 第一步:查看idea的jdk版本与Windows安装的jdk是不是同一个版本,如下图 第二 ...

  3. 用table类型布局一个新闻网页

    <html><head><meta http-equiv="Content-Type" content="text/html; charse ...

  4. 一些大厂的css reset 代码

    不同的浏览器对标签的默认值不同,为了避免页面出现浏览器差异,所以要初始化样式表属性.使用通配符*并不可取,因为会遍历到每一个标签,大型网页会加载过慢,影响性能. 雅虎工程师提供的CSS初始化示例代码: ...

  5. Python学习笔记--迭代

    在Python中,迭代是通过for ... in来实现.只要是可迭代的对象都可以用for ... in来进行历遍. 常用的有list.tuple.dict等.举例如下: 列表的迭代: L=[1,2,3 ...

  6. JZOJ 1774. 合并果子 (Standard IO)

    1774. 合并果子 (Standard IO) Time Limits: 1000 ms Memory Limits: 65536 KB Description 在一个果园里,多多已经将所有的果子打 ...

  7. Xml反序列化记录

    1.概述 公司项目遇到一个需要对接webservice的,webservice大部分用的都是xml来传输的,这里记录一下xml反序列化遇到的问题 2.xml工具类 xml序列化: public sta ...

  8. ios background task

    今天要实现一个需求,当用户触摸HOME键,将应用切换到后台时,启动自动备份的任务.这涉及到ios的后台任务处理,本文简单总结一下 首先,ios app有5种状态,分别是:not running, in ...

  9. Map - 与君初相识

    前言 生活中,我们常会看到这样一种集合:IP地址与主机名,身份证号与个人等,这种一 一对应的关系,就叫做映射.Java提供了专门的集合类用来存放这种对应关系的对象,即 java.util.Map 接口 ...

  10. Ajax上传数据和上传文件(三种方式)

    Ajax向后端发送数据可以有三种方式:原生Ajax方式,jQuery Ajax方式,iframe+form 方式(伪造Ajax方式) <!DOCTYPE html> <html la ...