首先按限制高度排序,然后按多重背包做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. laravel方法汇总详解

    1.whereRaw() 用原生的SQL语句来查询,whereRaw('select * from user') 就和 User::all()方法是一样的效果 2.whereBetween() 查询时 ...

  2. php获取数组中重复数据的两种方法

    分享下php获取数组中重复数据的两种方法. 1,利用php提供的函数,array_unique和array_diff_assoc来实现 <?php function FetchRepeatMem ...

  3. js替换字符串的所有示例代码

    js如何替换字符串中所有. /** * 替换字符串中所有 * @param obj 原字符串 * @param str1 替换规则 * @param str2 替换成什么 * @return 替换后的 ...

  4. CorelDRAW 插件的安装和使用

    CorelDRAW 是一款在中国非常受欢迎的图形软件,开放的界面和编程技术,能够对它进行二次开发制作插件,插件大抵有三种gms.cpg.exe格式,下面介绍一下这三种插件的安装和使用方法. 一.gms ...

  5. DB2中循环日期跑数据

    1.数据库版本: 2.具体实现方式: ),)) /*************************************************************************** ...

  6. 开始学习python

    刚刚离开学校,到公司实习,发现所有的技术都是崭新的,所有的工具都是熟悉中带着陌生. 就像是孤身一人到了一个曾经只闻其名的偌大城市,看什么都觉得新鲜,做什么都心有畏惧.幸好 搞软件并没有那么多人情世故, ...

  7. 【转】O'Reilly Java系列书籍建议阅读顺序(转自蔡学庸)

    Learning Java the O'Reilly's Way (Part I) Java 技术可以说是越来越重要了,不但可以用在计算机上,甚至连电视等家电用品,行动电话.个人数字助理(PDA)等电 ...

  8. collectionView代码创建

    @interface ViewController ()<UICollectionViewDataSource,UICollectionViewDelegateFlowLayout> @p ...

  9. DEDECMS采集规则,过滤,替换文章内的部分内容

    1.采集去除链接[Copy to clipboard]CODE:{dede:trim}]*)>([^<]*){/dede:trim}---------------------------- ...

  10. 李洪强iOS开发本人集成环信的经验总结_03_注册

    李洪强iOS开发本人集成环信的经验总结_03_注册 环信一共提供了三种注册的方法:  01 同步注册:  02 异步注册:  03 - 使用代理回调进行注册,但是3.0没有了,3.0之前有  调用注册 ...