最少区间覆盖问题;

首先我们想到将r排序,则以得出dp方程

f[i]=1 (l[i]=1)

=min{f[j]}+1 (r[j]+1>=l[i])

最后ans是min{f[j]} (r[j]>=t);

很显然O(n^2),会超时;

考虑到r已经升序排列,对于一个f[i],如果f[i]<f[j] (i>j) 显然,使用i覆盖比使用j覆盖更优;

于是我们想到用单调队列来优化,维护一个r[j],f[j]都单调增的队列,具体代码如下:

 var f,p,q,w:array[..] of longint;  //w为单调队列,存放标号
    ans,i,j,z,t,n,m:longint;
function find(x:longint):longint;   //查找
  var m,l,r,v:longint;
  begin
    l:=;
    r:=t;
    repeat                  //二分查找,常和单调队列联系使用
      m:=(l+r) div ;          
      if q[w[m]]+>=p[x] then
      begin
        r:=m-;
        v:=m;
      end else l:=m+;
    until l>r;
    exit(w[v]);
  end;
procedure putin;   //入队
  var l,r,m:longint;
  begin
    if f[i]>f[w[t]] then
    begin
      t:=t+;
      w[t]:=i;
    end
    else begin
      l:=;
      r:=t;
      repeat                        //寻找一个合适的位子
        m:=(l+r) div ;
        if (f[w[m]]>=f[i]) and (f[w[m-]]<f[i]) then break;
        if (f[w[m]]>=f[i]) then r:=m- else l:=m+;
      until l>r;
      t:=m;                         //由之前知,队列中m后面的一定不如当前的i优,退队
      w[m]:=i;
    end;
  end;
begin
  readln(n,m);
  for i:= to n do
    readln(p[i],q[i]);
  sort(,n); //以Q为关键字升序排序,省略
  for i:= to n do
  begin
    if p[i]<= then
    begin
      f[i]:=;
      putin;
      continue;
    end;
    z:=find(i);
    if z= then
    begin
      f[i]:=;
      continue;
    end;
    f[i]:=f[z]+;            //dp
    putin;
  end;
  ans:=;
  for i:=n downto do
    if q[i]>=m then ans:=min(ans,f[i]) else break;       //寻找最小值
  if ans= then writeln(-) else writeln(ans);
end.

易知复杂度为O(nlogn)可以AC

poj2376的更多相关文章

  1. poj2376 Cleaning Shifts(区间贪心,理解题意)

    https://vjudge.net/problem/POJ-2376 题意理解错了!!真是要仔细看题啊!! 看了poj的discuss才发现,如果前一头牛截止到3,那么下一头牛可以从4开始!!! # ...

  2. POJ2376 Cleaning Shifts

    题意 POJ2376 Cleaning Shifts 0x50「动态规划」例题 http://bailian.openjudge.cn/practice/2376 总时间限制: 1000ms 内存限制 ...

  3. 《挑战程序设计竞赛》2.2 贪心法-区间 POJ2376 POJ1328 POJ3190

    POJ2376 Cleaning Shifts Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 14585   Accepte ...

  4. POJ-2376 Cleaning Shifts---区间覆盖&贪心

    题目链接: https://vjudge.net/problem/POJ-2376 题目大意: farmer John要安排他的牛清理牛棚,一共有T个牛棚要清理,每头牛可以清理相邻的牛棚.比如,一头牛 ...

  5. poj-2376 Cleaning Shifts (排序+贪心)

    http://poj.org/problem?id=2376 john有n头牛做打扫工作,他想在t时间内每个时间都至少有一头牛在做打扫工作,第一头牛在1,最后一头牛在t时间,每一头牛工作都有一个开始时 ...

  6. 贪心算法----区间覆盖问题(POJ2376)

    题目: 题目的大概意思是约翰这个农民有N条牛,这些牛可以在一天中的某个时间段可以进行工作,他想把这个时间段分成若干个片段让这些牛去进行打扫任务,你的任务是安排尽量少的牛然后可以完成分成这些片段的打扫任 ...

  7. 【贪心算法】POJ-2376 区间问题

    一.题目 Description Farmer John is assigning some of his N (1 <= N <= 25,000) cows to do some cle ...

  8. poj2376 Cleaning Shifts【线段树】【DP】

    Cleaning Shifts Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 32561   Accepted: 7972 ...

  9. POJ2376 Cleaning Shifts 【贪心】

    Cleaning Shifts Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 11542   Accepted: 3004 ...

随机推荐

  1. Cassandra1.2文档学习(19)—— CQL索引

    参考文档:http://www.datastax.com/documentation/cql/3.0/webhelp/index.html#cql/ddl/ddl_primary_index_c.ht ...

  2. mysql实例---sql语句中使用@变量

    本文介绍下,在mysql语句中使用@变量的一个例子,学习下这个特殊变量的用法,有需要的朋友参考下吧. 要求: 计算用户距上次访问的天数,根据imei号区分不同的用户,如果时间段内只有一次访问则为0. ...

  3. PHPCMS 错误日志 Only variables should be passed by ...

    有几个网站是PHPCMS V9做的,但这两天发现一个问题,PHPCMS 的错误日志超过了20M ,后台报警,然后我看了下错误日志,其中两万多行都是一个错误,错误信息如下: 1 <?php exi ...

  4. Cadence封装制作之表贴封装的制作

    以0805封装为例 1.打开PCB editor-> Allegro PCB Design XL 2.File -> New ① Drawing Type -> Package Sy ...

  5. 3141: [Hnoi2013]旅行 - BZOJ

    Description Input 第一行为两个空格隔开的正整数n, m,表示旅行的城市数与旅行所花的月数.接下来n行,其中第 i行包含两个空格隔开的整数Ai和Bi,Ai表示他第i个去的城市编号.Bi ...

  6. The 6th Zhejiang Provincial Collegiate Programming Contest->Problem I:A Stack or A Queue?

    http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3210 题意:给出stack和queue的定义,一个是先进后出(FILO), ...

  7. uva 10271

    DP  状态转移方程 dp[i][j] = min(dp[i-1][j], dp[i-2][j-1] + w)) dp[i][j] 指的是前i个筷子组成j组所花费的最小值 考虑第i个筷子是否参与第j组 ...

  8. Jenkins任务启动的后台进程被自动kill

    在Jenkins的使用中,遇到过的一个场景是:在web代码更改之后,能自动的部署到测试服务器,我们写了run.sh脚本来重启服务,在使用Jenkins的任务自动跑这个脚本后发现,服务没有起来.开始以为 ...

  9. SaaS 公司如何应对 On-Call 挑战?

    Cloud Insight 集监控.管理.计算.协作.可视化于一身,帮助所有 IT 公司,减少在系统监控上的人力和时间成本投入,让运维工作更加高效.简单.本文系国内 ITOM 行业领军企业 OneAP ...

  10. Oracle sql查询

    http://blog.csdn.net/jlds123/article/details/6572559