[BZOJ2196]Brownie Slicing 二分答案

二维的二分答案。
代码:

var
  r,c,a,b,i,j,li,re,mid:longint;
  d,s:array[0..510,0..510]of longint;
function cal(x1,y1,x2,y2:longint):longint;
begin
  exit(s[x2,y2]-s[x2,y1-1]-s[x1-1,y2]+s[x1-1,y1-1]);
end;
function check(x:longint):boolean;
var
  i,j,lasta,lastb,na,nb:longint;
begin
  lasta:=1;
  for na:=1 to a do
  begin
    for i:=lasta to r+1 do
    begin
      lastb:=1;
      for nb:=1 to b do
      begin
        for j:=lastb to c+1 do
          if cal(lasta,lastb,i,j)>=x then break;
        lastb:=j+1;
        if lastb>c then break;
      end;
      if (nb=b)and(lastb<=c+1) then break;
    end;
    lasta:=i+1;
    if lasta>r then break;
  end;
  exit((na=a)and(lasta<=r+1));
end;

begin
  readln(r,c,a,b);
  for i:=1 to r do
    for j:=1 to c do
    begin
      read(s[i,j]);
      s[i,j]:=s[i,j]+s[i-1,j]+s[i,j-1]-s[i-1,j-1];
    end;
  li:=0;
  re:=1000000000;
  while li<re do
  begin
    mid:=(li+re)div 2;
    if check(mid) then li:=mid+1
    else re:=mid;
  end;
  writeln(li-1);
end.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值