首先按限制高度排序,然后按多重背包做dp

这里的背包只用知道每种状态是否可行,所以

这里的多重背包可以变成O(nm)

 const max=;
var f:array[..,..,..] of longint;
    a,b:array[..] of longint;
    i,j,k1,k2,n,k,m,w,ans,t:longint;
function findmin(t:longint):longint;
  var p,k:longint;
  begin
    p:=max;
    for k:= to do
      p:=min(p,f[k1,j-t,k]);
    exit(p);
  end;
procedure sort(l,r: longint); //按列排序,上下都有牛时1在前2在后,这样处理dp的时候方便多
  var i,j,x,y: longint;
  begin
    i:=l;
    j:=r;
    x:=a[(l+r) div ];
    y:=b[(l+r) div ];
    repeat
      while (a[i]<x) or (a[i]=x) and (b[i]<y) do inc(i);
      while (x<a[j]) or (a[j]=x) and (b[j]>y) do dec(j);
      if not(i>j) then
      begin
        swap(a[i],a[j]);
        swap(b[i],b[j]);
        inc(i);
        j:=j-;
      end;
    until i>j;
    if l<j then sort(l,j);
    if i<r then sort(i,r);
  end; procedure doit1;
  begin
    f[k2,j,]:=min(f[k2,j,],f[k1,j,]+*(a[i]-a[i-]));
    f[k2,j,]:=min(findmin()+,f[k2,j,]);
  end; procedure doit2;
  var p:longint;
  begin
    f[k2,j,]:=min(f[k1,j,]+*(a[i]-a[i-]),f[k2,j,]);
    p:=min(min(f[k1,j-,],f[k1,j-,]),f[k1,j-,]);
    f[k2,j,]:=min(f[k2,j,],p+a[i]-a[i-]+);
    if j->= then
      f[k2,j,]:=min(f[k2,j,],findmin()+);
  end; procedure doit(x:longint);
  var p:longint;
  begin
    p:=min(f[k1,j,x],f[k1,j,]);
    f[k2,j,x]:=min(f[k2,j,x],p+a[i]-a[i-]);
    f[k2,j,x]:=min(f[k2,j,x],findmin()+);
  end; begin
  readln(n,k,m);
  for i:= to n do
    readln(b[i],a[i]);
  sort(,n);
  for i:= to k do  //初始化
    for j:= to do
    begin
      f[,i,j]:=max;
      f[,i,j]:=max;
    end;
  i:=;
  f[,,]:=;
  if a[i]=a[i+] then
  begin
    i:=;
    f[,,]:=;
  end
  else begin
    i:=;
    if b[]= then f[,,]:=
    else f[,,]:=;
  end;
  k1:=;
  k2:=;
  while i<=n do
  begin
    k1:=k1 xor ; //滚动数组
    k2:=k2 xor ;
    if a[i]=a[i+] then w:= else w:=;
    for j:= to k do
    begin
      for t:= to do
        f[k2,j,t]:=max;
      doit1;  //做4个状态,方程式自己动手比划一下就明白了
      doit2;
      if w= then
      begin
        if b[i]= then
          doit()
        else doit();
      end;
    end;
    i:=i+w;
  end;
  ans:=max;
  for i:= to do
    ans:=min(ans,f[k2,k,i]);
  writeln(ans);
end.

注意:一般的多重背包复杂度到O(nm)必须使用单调队列,这里是特殊情况

poj2392的更多相关文章

  1. 多重背包问题:POJ2392

    这是一道完全背包问题,只不过增加了限制条件. 在更新最大值的时候,我注释掉了错误的方式,却不明白为什么是错误的,如果有人看到这篇博客,并且知道为什么那样更新是错误的,请指教,谢谢. 上代码: #inc ...

  2. poj2392 多重背包

    //Accepted 868 KB 188 ms //多重背包 #include <cstdio> #include <cstring> #include <iostre ...

  3. poj2392 Space Elevator(多重背包)

    http://poj.org/problem?id=2392 题意: 有一群牛要上太空.他们计划建一个太空梯-----用一些石头垒.他们有K种不同类型的石头,每一种石头的高度为h_i,数量为c_i,并 ...

  4. POJ2392 SpaceElevator [DP]

    题目大意:有一头奶牛要上太空,他有非常多种石头,每种石头的高度是hi,可是不能放到ai之上的高度.而且这样的石头有ci个 将这些石头叠加起来.问可以达到的最高高度. 解题思路:首先对数据进行升序排序. ...

  5. Space Elevator [POJ2392] [DP][优化]

    题目大意 n件物品,第i件hi高,有ci件,最高的一件不能超过ai的高度.问最高能堆多高 输入: 第一行,一个n 接下来每一行,为hi,ai,ci 输出,最高堆多高 样例输入: 37 40 35 23 ...

  6. POJ2392 Space Elevator

    题目:http://poj.org/problem?id=2392 一定要先按高度限制由小到大排序! 不然就相当于指定了一个累加的顺序,在顺序中是不能做到“只放后面的不放前面的”这一点的! 数组是四十 ...

  7. dp之多重背包poj2392

    题意:有k种石头,高为hi,在不超过ai的高度下,这种石头可以放置,有ci种这个石头,求这些石头所能放置的最高高度......... 思路:以往的什么硬币种数,最大硬币数之类的,他们的硬币都已经是排好 ...

  8. poj2392 Space Elevator(多重背包问题)

    Space Elevator   Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 8569   Accepted: 4052 ...

  9. poj2392磊石头——排序后背包

    题目: 首先按限制高度从小到大排序,不会影响可行解,而不排序可能卡掉正确的情况: 用%2滚动数组时一定注意每次复制上一种情况,因为这个WA了好几次. 代码如下: #include<iostrea ...

随机推荐

  1. 代码动态创建checkbox

    根据数据库的内容动态创建Checkbox控件并显示在Panel上 dataset ds=new dataset(); CheckBox[ ] cb=new CheckBox[ds.tables[0]. ...

  2. PHP学习之环境搭建

    计算机环境 win7  64位 搭建  apache-httpd-2.2-win64  +  php-5.3.6-Win32-VC9-x64  +MySQL_5.5.13_winx64开发环境 参考: ...

  3. 直接下载完整chrome浏览器的方法

    目前通过下吗的链接可以获得独立的安装包. http://www.google.com/chrome/eula.html?standalone=1&hl=zh-CN

  4. (转载)异构数据库之间完全可以用SQL语句导数据

    <来源网址:http://www.delphifans.com/infoview/Article_398.html>异构数据库之间完全可以用SQL语句导数据 告诉你一个最快的方法,用SQL ...

  5. Sharing

    To store English words, one method is to use linked lists and store a word letter by letter. To save ...

  6. PL/SQL数据导入导出浅谈(1)

    近来需要通过PL/SQL向Oracle中导数据,特此总结一下 试例表:test 字段:id;name;org; 1.直接复制粘贴(当数据量不是特别大的时候) 1)使用select * from tes ...

  7. MQ 2035(MQRC_NOT_AUTHORIZED)

    当使用MQ7.1或7.5时,如果使用MQ管理员账号去连接MQ服务器,可能会报以下的错误,提示你权限不足. 2035 MQRC_NOT_AUTHORIZED 在之前的版本中是没有这个问题的. 原因是在7 ...

  8. 【BZOJ 2878】 [Noi2012]迷失游乐园

    Description 放假了,小Z觉得呆在家里特别无聊,于是决定一个人去游乐园玩.进入游乐园后,小Z看了看游乐园的地图,发现可以将游乐园抽象成有n个景点.m条道路的无向连通图,且该图中至多有一个环( ...

  9. 根据不同ip进入不同页面

    function GetIP() { $cip = ""; if(!empty($_SERVER["HTTP_CLIENT_IP"])){ $cip = $_S ...

  10. bzoj 2744: [HEOI2012]朋友圈 二分图匹配

    2744: [HEOI2012]朋友圈 Time Limit: 30 Sec  Memory Limit: 128 MBSubmit: 612  Solved: 174[Submit][Status] ...