BZOJ 2196: [Usaco2011 Mar]Brownie Slicing( 二分答案 )

时间:2022-09-19 16:22:06

BZOJ 2196: [Usaco2011 Mar]Brownie Slicing( 二分答案 )

二分答案就可以了....

-----------------------------------------------------------------------

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
#include<cctype>
 
using namespace std;
 
typedef long long ll;
 
inline int read() {
char c = getchar();
int ret = 0;
for(; !isdigit(c); c = getchar());
for(; isdigit(c); c = getchar()) ret = ret * 10 + c - '0';
return ret;
}
 
const int maxn = 509;
 
int mat[maxn][maxn], sum[maxn][maxn], t[maxn], N, M, A, B;
 
bool ok(int p, int c, int x) {
if(sum[c][M] - sum[p][M] < x * B) return false;
for(int i = 0; i <= M; i++)
t[i] = sum[c][i] - sum[p][i];
int _c = 1, _p = 0;
for(int i = 0; i < B; i++) {
while(t[_c] - t[_p] < x) 
if(++_c > M) return false;
_p = _c;
}
return true;
}
 
bool check(int x) {
int p = 0, c = 1;
for(int i = 0; i < A; i++) {
while(!ok(p, c, x)) 
if(++c > N) return false;
p = c;
}
return true;
}
 
int main() {
N = read(); M = read(); A = read(); B = read();
for(int i = 1; i <= N; i++) {
sum[i][0] = 0;
for(int j = 1; j <= M; j++)
sum[i][j] = sum[i][j - 1] + (mat[i][j] = read());
}
for(int j = 1; j <= M; j++) {
sum[0][j] = 0;
for(int i = 1; i <= N; i++)
sum[i][j] += sum[i - 1][j];
}
int ans, L = 0, R = int(1e9);
while(L <= R) {
int m = (L + R) >> 1;
if(check(m))
ans = m, L = m + 1;
else
R = m - 1;
}
cout << ans << "\n";
return 0;
}

-----------------------------------------------------------------------

2196: [Usaco2011 Mar]Brownie Slicing

Time Limit: 10 Sec  Memory Limit: 259 MB
Submit: 183  Solved: 123
[Submit][Status][Discuss]

Description

Bessie烘焙了一块巧克力蛋糕。这块蛋糕是由R*C(1 <= R,C <= 500)个小的巧克力蛋糕组成的。 第i行,第j列的蛋糕有N_ij(1 <= N_ij <= 4,000)块巧克力碎屑。 Bessie想把蛋糕分成A*B块,(1 <= A <= R,1 <= B <= C): 给A*B只奶牛。蛋糕先水平地切A-1刀 (只能切沿整数坐标切)来把蛋糕划分成A块。然后再把剩下来的每一块独立地切B-1刀, 也只能切沿整数坐标切。其他A*B-1只奶牛就每人选一块,留下一块给Bessie。由于贪心, 他们只会留给Bessie巧克力碎屑最少的那块。 求出Bessie最优情况下会获得多少巧克力碎屑。 例如,考虑一个5*4的蛋糕,上面的碎屑分布如下图所示: 1 2 2 1 3 1 1 1 2 0 1 3 1 1 1 1 1 1 1 1 Bessie必须把蛋糕切成4条,每条分成2块。Bessie能像这样切蛋糕: 1 2 | 2 1 --------- 3 | 1 1 1 --------- 2 0 1 | 3 --------- 1 1 | 1 1 1 1 | 1 1 因此,其他贪得无厌的牛拿完后,Bessie仍能够拿走3个巧克力碎屑。

Input

* 第1行: 四个空格隔开的数: R, C, A ,B * 第2-R+1行: 第i+1行有C个整数, N_i1 , N_i2 .. N_iC

Output

* 第1行: 一个整数: Bessie保证能拿到的最多碎屑数

Sample Input

5 4 4 2
1 2 2 1
3 1 1 1
2 0 1 3
1 1 1 1
1 1 1 1

Sample Output

3

HINT

Source

BZOJ 2196: [Usaco2011 Mar]Brownie Slicing( 二分答案 )的更多相关文章

  1. BZOJ&lowbar;2196&lowbar;&lbrack;Usaco2011 Mar&rsqb;Brownie Slicing&lowbar;二分答案&plus;贪心

    BZOJ_2196_[Usaco2011 Mar]Brownie Slicing_二分答案+贪心 Description Bessie烘焙了一块巧克力蛋糕.这块蛋糕是由R*C(1 <= R,C ...

  2. 【BZOJ】2196&colon; &lbrack;Usaco2011 Mar&rsqb;Brownie Slicing

    [题意]给定n*m的数字矩阵,要求横着切A-1刀,对每块再分别竖着切B-1刀,是最小子矩阵最大. [算法]二分+贪心 [题解]还记得提高组2015跳石头吗?这道题做法一致,只不过拓展到二维而已. 二分 ...

  3. BZOJ2196&colon; &lbrack;Usaco2011 Mar&rsqb;Brownie Slicing

    n<=500 * m<=500的方阵,先沿横坐标切A-1刀,再把每一块切B-1刀,得到A*B块,求这A*B块的数字之和的最小值的最大值. 最小值最大--二分,然后贪心切.每次扫一行,看这一 ...

  4. bzoj 1614 Telephone Lines架设电话线 - 二分答案 - 最短路

    Description Farmer John打算将电话线引到自己的农场,但电信公司并不打算为他提供免费服务.于是,FJ必须为此向电信公司支付一定的费用. FJ的农场周围分布着N(1 <= N ...

  5. BZOJ 3993 &lbrack;SDOI2015&rsqb;星际战争 &vert; 网络流 二分答案

    链接 BZOJ 3993 题解 这道题挺棵的-- 二分答案t,然后源点向武器连t * b[i], 武器向能攻击的敌人连1, 敌人向汇点连a[i],如果最大流等于所有敌人的a[i]之和则可行. #inc ...

  6. BZOJ 1189&colon; &lbrack;HNOI2007&rsqb;紧急疏散evacuate&lpar; BFS &plus; 二分答案 &plus; 匈牙利 &rpar;

    我们可以BFS出每个出口到每个人的最短距离, 然后二分答案, 假设当前答案为m, 把一个出口拆成m个表示m个时间, 点u到出口v的距离为d, 那么u->v的[d, m]所有点连边, 然后跑匈牙利 ...

  7. BZOJ 1305 dance跳舞&lpar;最大流&plus;二分答案&rpar;

    题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1305 解题思路:转自:https://blog.csdn.net/u012288458/ ...

  8. bzoj 1901 线段树套平衡树&plus;二分答案查询

    我们就建一颗线段树,线段树的每一个节点都是一颗平衡树,对于每个询问来说,我们就二分答案, 查询每个二分到的mid在这个区间里的rank,然后就行了 /************************* ...

  9. BZOJ 4326 NOIP2015 运输计划(二分答案 &plus; 树上差分思想)

    题目链接  BZOJ4326 这个程序在洛谷上TLE了……惨遭卡常 在NOIP赛场上估计只能拿到95分吧= = 把边权转化成点权 首先求出每一条路径的长度 考虑二分答案,$check(now)$ 对于 ...

随机推荐

  1. 【repost】document&period;write的用处

    document.write的用处 document.write是JavaScript中对document.open所开启的文档流(document stream操作的API方法,它能够直接在文档流中 ...

  2. javascript数据结构与算法---列表

    javascript数据结构与算法---列表 前言:在日常生活中,人们经常要使用列表,比如我们有时候要去购物时,为了购物时东西要买全,我们可以在去之前,列下要买的东西,这就要用的列表了,或者我们小时候 ...

  3. 编码转换的处理 DreamWeaver SC6 打开会出现javacsript出现问题的处理

      编码转换的处理: 打开DW后,修改里面有个"页面属性": 点击页面属性,会弹出一个窗口,点击"标题/编码",在"编码"里面选择你要转换的 ...

  4. Xocde4与Xcode3的模板比较

    XCode 4.2.1 项目的模版截图: Single View Application This template provides a starting point for an applicat ...

  5. JS-事件之鼠标、键盘都能控制的下拉选框效果

    <script type="text/javascript"> window.onload=function(e){ var box=document.getEleme ...

  6. 数组Arrays

    1.toString 方法 Arrays的toString方法可以方便的输出一个数组的字符串形式,方便查看,它有九个重载的方法,包括八种基本类型数组和一个对象类型数组,这里列举两个: public s ...

  7. ArcGIS Engine要素渲染和专题图制作(转)

    摘要:Feature的常用的绘制方法包括:1.简单绘制:2.唯一值绘制/多字段唯一值绘制:3.点密度/多字段点密度绘制:4.数据分级绘制:5.质量图(饼图/直方图): 6.按比例尺渲染:7.比例符号渲 ...

  8. duilib&bsol;utils&bsol;utils&period;h&lpar;251&rpar; &colon; error C2504&colon; &OpenCurlyDoubleQuote;VARIANT”&colon; 未定义基类

    转载:http://blog.csdn.net/SP_daiyq/article/details/44542939?locationNum=3 创建win32应用程序的工程文件,删除不需要的代码,只留 ...

  9. &lbrack;快速幂&rsqb;&lbrack;NOIP2012&rsqb;转圈游戏

    转圈游戏 题目描述 n 个小伙伴(编号从 0 到 n-1)围坐一圈玩游戏.按照顺时针方向给 n 个位置编号,从0 到 n-1.最初,第 0 号小伙伴在第 0 号位置,第 1 号小伙伴在第 1 号位置, ...

  10. Shell流程控制(if&comma;else&comma;case&comma;while&comma;for&comma;until)

    1.条件选择 1.1.if 语句 语法十分简单 #!/bin/bash MATH_SCORES="$1" NAME="$2" if [ -z "${M ...