这两题本质是一致的;

一般来说,对于最长(短)化最短(长)的问题我们一般都使用二分答案+判定是否可行

因为这样的问题,我们一旦知道答案,就能知道全局信息

拿poj2455举例,对于二分出的一个答案,我们将不符合的边全部去掉,在做一遍最大流判断是否成立即可

注意这道题有重边,所以用链式前向星比较好(TT,当时我用的数组模拟邻接表表不要太烦)

 type node=record
       po,flow,cost:longint;
     end;
var w,ow:array[..,..] of node;
    cur,pre,numh,h,s,s0:array[..] of longint;
    ans,max,mid,l,r,x,y,z,i,n,m,p:longint; procedure add(x,y,z,f:longint);  //很繁琐的结构,需要检查好久,重边优先选择链式前向星,比较方便
  begin
    inc(s[x]);
    w[x,s[x]].po:=y;
    w[x,s[x]].cost:=z;
    w[x,s[x]].flow:=f;
  end; function maxflow(k:longint):boolean;  //很喜欢写sap,判定
  var j,sum,u,i,t,r,tmp:longint;
  begin
    max:=-;
    fillchar(pre,sizeof(pre),);
    fillchar(cur,sizeof(cur),);
    fillchar(h,sizeof(h),);
    fillchar(numh,sizeof(numh),);   //一定要注意,这句话没有不影响程序结果,但会拖慢程序速度(相当于没用到GAP优化),谨记
    fillchar(s0,sizeof(s0),);
    for i:= to n do
      for j:= to s[i] do
      begin
        if w[i,j].cost<=k then     //根据条件构造新图
        begin
          inc(s0[i]);
          ow[i,s0[i]]:=w[i,j];
        end;
      end;
    numh[]:=n;
    sum:=;
    u:=;
    while h[]<n do
    begin
      if u=n then
      begin
        i:=;
        while i<>n do
        begin
          t:=cur[i];
          if max<ow[i,t].cost then max:=ow[i,t].cost;  //小优化而已,在最大流里面找一条最大的边,实际上答案是这个
          dec(ow[i,t].flow);
          i:=ow[i,t].po;
        end;
        inc(sum);
        if sum=p then exit(true);
        u:=;
      end;
      r:=-;
      for i:= to s0[u] do
        if (ow[u,i].flow>) and (h[u]=h[ow[u,i].po]+) then
        begin
          r:=i;
          break;
        end;       if r<>- then
      begin
        cur[u]:=r;
        pre[ow[u,r].po]:=u;
        u:=ow[u,r].po;
      end
      else begin
        dec(numh[h[u]]);
        if numh[h[u]]= then exit(false);   
        tmp:=n;   //注意这里千万不要顺手打成maxlongint之类
        for i:= to s0[u] do
          if (ow[u,i].flow>) and (tmp>h[ow[u,i].po]) then tmp:=h[ow[u,i].po];
        h[u]:=tmp+;
        inc(numh[h[u]]);
        if u<> then u:=pre[u];
      end;
    end;
    exit(false);
  end; begin
  readln(n,m,p);
  for i:= to m do
  begin
    readln(x,y,z);
    add(x,y,z,);
    add(y,x,z,);
    if z>r then r:=z;
  end;
  l:=;
  while l<=r do
  begin
    mid:=(l+r) shr ;
    if maxflow(mid) then  
    begin
      ans:=max;   //小小的优化,但不是所有二分判定都可以用
      r:=max-;
    end
    else l:=mid+;
  end;
  writeln(ans);
end.

poj2391也是一样的,只不过多了floyd预处理

一般的,对于答案越大,决策就越有可能成功的这类具有单调性的题目,通常使用二分答案

poj2391,poj2455的更多相关文章

  1. Pyhton开源框架(加强版)

    info:Djangourl:https://www.oschina.net/p/djangodetail: Django 是 Python 编程语言驱动的一个开源模型-视图-控制器(MVC)风格的 ...

  2. MPlayer

    名称   mplayer − 电影播放器 mencoder − 电影编解码器 概要   mplayer [选项] [文件|URL|播放列表|−] mplayer [选项] 文件1 [指定选项] [文件 ...

  3. python 爬取腾讯微博并生成词云

    本文以延参法师的腾讯微博为例进行爬取并分析 ,话不多说 直接附上源代码.其中有比较详细的注释. 需要用到的包有 BeautifulSoup WordCloud jieba # coding:utf-8 ...

  4. 面经 cisco

    1. 优先级反转问题及解决方法 (1)什么是优先级反转 简单从字面上来说,就是低优先级的任务先于高优先级的任务执行了,优先级搞反了.那在什么情况下会生这种情况呢? 假设三个任务准备执行,A,B,C,优 ...

  5. linux驱动(续)

    网络通信 --> IO多路复用之select.poll.epoll详解 IO多路复用之select.poll.epoll详解      目前支持I/O多路复用的系统调用有 select,psel ...

  6. HttpServletRequest对象(一)

    javaweb学习总结(十)——HttpServletRequest对象(一) 一.HttpServletRequest介绍 HttpServletRequest对象代表客户端的请求,当客户端通过HT ...

  7. POJ2455 Secret Milking Machine【二分,最大流】

    题目大意:N个点P条边,令存在T条从1到N的路径,求路径上的边权的最大值最小为多少 思路:做了好多二分+最大流的题了,思路很好出 二分出最大边权后建图,跑dinic 问题是....这题是卡常数的好题! ...

  8. 【poj2455】 Secret Milking Machine

    http://poj.org/problem?id=2455 (题目链接) 题意 给出一张n个点,p条边的无向图,需要从1号节点走到n号节点一共T次,每条边只能经过1次,问T次经过的最大的边最小是多少 ...

  9. poj2391 Ombrophobic Bovines 拆点+二分法+最大流

    /** 题目:poj2391 Ombrophobic Bovines 链接:http://poj.org/problem?id=2391 题意:有n块区域,第i块区域有ai头奶牛,以及一个可以容纳bi ...

随机推荐

  1. linux 输入子系统(4)---- input子系统的初始化

    Input子系统的初始化函数为input_init(),如下: static int __init input_init(void) { int err; input_init_abs_bypass( ...

  2. 初次接触pyqt

    基本了解了pyqt的原理,到http://www.riverbankcomputing.co.uk/news下载安装好qt后,桌面上会出现Qt Designer. 我们可以利用它进行界面的设计,然后保 ...

  3. Only the original thread that created a view hierarchy can touch its views

    在调试软件的时候出现如下的错误: 01-05 20:53:36.492: E/ZZShip(2043): android.view.ViewRootImpl$CalledFromWrongThread ...

  4. Asp.net MVC入门视频教程

    编程开发 > Asp.net视频教程 > Asp.net MVC入门视频教程 > 1.传统web处理方式和mvc处理方式 上传日期:2014-08-16 10:02:45  相关摘要 ...

  5. 【BZOJ 2440】[中山市选2011]完全平方数

    Description 小 X 自幼就很喜欢数.但奇怪的是,他十分讨厌完全平方数.他觉得这些数看起来很令人难受.由此,他也讨厌所有是完全平方数的正整数倍的数.然而这丝毫不影响他对其他数的热爱. 这天是 ...

  6. Tomcat 搭配 Nginx 还是 Apache 呢?

    Apache .Tomcat.Nginx的区别, 哪个与Tomcat搭配效率高? 一. 定义: 1. Apache Apache HTTP服务器是一个模块化的服务器,可以运行在几乎所有广泛使用的计算机 ...

  7. 3.9 spring-自定义标签解析

    到这里,我们已经完成了分析默认标签的解析与提取过程,或许设计的内容太多,我们忘了我们是冲哪个函数开始了的, 让我们再次回顾一下默认标签解析方法的起始方法. 入口如下: /** * Parse the ...

  8. 【string】KMP, 扩展KMP,trie,SA,ACAM,SAM,最小表示法

    [KMP] 学习KMP,我们先要知道KMP是干什么的. KMP?KMPLAYER?看**? 正如AC自动机,KMP为什么要叫KMP是因为它是由三个人共同研究得到的- .- 啊跑题了. KMP就是给出一 ...

  9. [转载]MongoDB优化的几点原则

    .查询优化 确认你的查询是否充分利用到了索引,用explain命令查看一下查询执行的情况,添加必要的索引,避免扫表操作. .搞清你的热数据大小 可能你的数据集非常大,但是这并不那么重要,重要的是你的热 ...

  10. klayge 4.2.0 编译vc9

    CMake Error at CMakeLists.txt:442 (ADD_PRECOMPILED_HEADER): Unknown CMake command "ADD_PRECOMPI ...