#include<stdio.h>

#include<queue>

#include<string.h>

using namespace std;

#define inf 0x7fffffff

#define N 300

int p,t,n;

int Min(int a,int b) {

return a>b?b:a;

}

struct node {

   int u,v,w,f;

}mp[40001];

int flow[N][N],d[N];

int bfs() {

 int cur,i;

 queue<int>q;

 memset(d,0,sizeof(d));

 d[1]=1;

   q.push(1);

    while(!q.empty()) {

        cur=q.front();

        q.pop();

        for(i=1;i<=n;i++)

     if(flow[cur][i]&&!d[i]) {

          d[i]=d[cur]+1;

          if(i==n)

            return 1;

           q.push(i);

     }

    }

    return 0;

}

int dfs(int u,int limit) {

    if(u==n)

        return limit;

  int cost=0,i,k;

 for(i=1;i<=n;i++)

    if(d[i]==d[u]+1&&flow[u][i]) {

        k=dfs(i,Min(limit-cost,flow[u][i]));

        if(k>0) {

            flow[u][i]-=k;

            flow[i][u]+=k;

            cost+=k;

            if(cost==limit)

                break;

        }

        else

            d[i]=-1;

    }

    return cost;

}

int dinic (int mid) {

   int ans=0,i;

    memset(flow,0,sizeof(flow));

  for(i=1;i<=p;i++)

    if(mp[i].w<=mid) {

   flow[mp[i].u][mp[i].v]++;

   flow[mp[i].v][mp[i].u]++;

    }

   while(bfs())

    ans+=dfs(1,inf);

     if(ans>=t)

        return 1;

     return 0;

}

int main() {

      int i,min,max,mid;

      while(scanf("%d%d%d",&n,&p,&t)!=EOF) {

            min=inf;

      max=-1;

         for(i=1;i<=p;i++) {

            scanf("%d%d%d",&mp[i].u,&mp[i].v,&mp[i].w);

            if(mp[i].w>max)

                max=mp[i].w;

            if(mp[i].w<min)

                min=mp[i].w;

         }

          while(min<=max) {

            mid=(min+max)/2;

            if(dinic(mid))

                max=mid-1;

            else

                min=mid+1;

          }

          printf("%d\n",min);

      }

return 0;

}

nyoj 310二分+dinic的更多相关文章

  1. poj 2391 Ombrophobic Bovines, 最大流, 拆点, 二分, dinic, isap

    poj 2391 Ombrophobic Bovines, 最大流, 拆点, 二分 dinic /* * Author: yew1eb * Created Time: 2014年10月31日 星期五 ...

  2. POJ2391 Floyd+离散化+二分+DINIC

    题意:       有n个猪圈,每个猪圈里面都有一定数量的猪(可能大于当前猪圈的数量),每个猪圈都有自己的容量,猪圈与猪圈之间给出了距离,然后突然下雨了,问多久之后所有的猪都能进圈. 思路:     ...

  3. Optimal Milking(POJ2112+二分+Dinic)

    题目链接:http://poj.org/problem?id=2112 题目: 题意:有k台挤奶机,c头奶牛,每台挤奶机每天最多生产m的奶,给你每个物品到其他物品的距离(除了物品到自己本省的距离为0外 ...

  4. POJ 3189 二分+Dinic

    题意: 思路: 二分跨度 枚举最低座次 建图:源点向每头牛连边权为1的边 每头牛向当前枚举的B的区间这段连上边权为1的边 所有座次向汇点连边权为牛棚容量的边 判判流量是不是等于n 一开始写得是直接枚举 ...

  5. nyoj-310-河南省第四届省赛题目-二分+dinic

    SECRET 时间限制:3000 ms  |  内存限制:65535 KB 难度:6   描述 Dr.Kong is constructing a new machine and wishes to ...

  6. nyoj 306 二分+dfs

    #include<stdio.h> #include<string.h> #define N 200 int Min(int a,int b) { return a>b? ...

  7. JSOI2018R2题解

    D1T1:潜入行动 裸的树上DP.f[i][j][0/1][0/1]表示以i为根的子树放j个设备,根有没有放,根有没有被子树监听,的方案数.转移显然. #include<cstdio> # ...

  8. 2019 wannafly winter camp day5-8代码库

    目录 day5 5H div2 Nested Tree (树形dp) 5F div2 Kropki (状压dp) 5J div1 Special Judge (计算几何) 5I div1 Sortin ...

  9. poj 2112 floyd+Dinic最大流+二分最小值

    题目大意是: K台挤奶机器,C头牛,K不超过30,C不超过200,每台挤奶机器最多可以为M台牛工作,给出这些牛和机器之间,牛和牛之间,机器与机器之间的距离,在保证让最多的牛都有机器挤奶的情况下,给出其 ...

随机推荐

  1. JSP-Runoob:JSP 发送邮件

    ylbtech-JSP-Runoob:JSP 发送邮件 1.返回顶部 1. JSP 发送邮件 虽然使用JSP实现邮件发送功能很简单,但是需要有JavaMail API,并且需要安装JavaBean A ...

  2. opensStack

  3. K8S之利用Label控制Pod位置

    首先介绍下什么是Label? Label是Kubernetes系列中一个核心概念.是一组绑定到K8s资源对象上的key/value对.同一个对象的labels属性的key必须唯一.label可以附加到 ...

  4. php 时间戳和时间的转换

    PHP的时间戳与具体时间转化 三个内置函数: time() //获取UNIX系统时间戳 mktime(hour,minute,second,month,day,year) //将指定时间转化为时间戳 ...

  5. [App Store Connect帮助]二、 添加、编辑和删除用户(2)查看并编辑您的个人帐户

    您可以在 App Store Connect 的“编辑个人资料”中查看和编辑个人信息.如果您的 Apple ID 与多个帐户相关联,您可以在您的用户帐户之间切换. 查看您的个人帐户 在任意 App S ...

  6. [Swift通天遁地]九、拔剑吧-(6)使用开源类库快速搭建强大的侧边栏项目

    ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...

  7. SS配置,Brook是什么?,Brook如何配置(Android篇)

    很长时间没有更新了,今天给大家分享一下什么是Brook,和SS有什么区别?写的不好,请勿见外,大佬绕过. Brook简单介绍 Brook 是一个高效的 Socks5 代理软件,官方支持Windows. ...

  8. 自定义View(9)使用Renderscript 渲染特效。

    1.渲染脚本官网 https://developer.android.com/guide/topics/renderscript/compute 2.高斯模糊 ScriptIntrinsicBlur ...

  9. Boost Bimap示例

    #include <string> #include <iostream> #include <boost/bimap.hpp> template< clas ...

  10. 通过yum命令搭建lamp环境(centos6.5)

    centos 6.5 1.yum安装和源代码编译在使用的时候没啥区别,但是安装的过程就大相径庭了,yum只需要3个命令就可以完成,源代码需要13个包,还得加压编译,步骤很麻烦,而且当做有时候会出错,源 ...