Content

小 S 想买下一块地。他所在的城市可以看成一个 \(n\times m\) 的网格,要购买所处在 \((i,j)\) 的网格需要缴税 \(c_{i,j}\) 元,如果一块地里面有多个网格,则所要缴的税为每个网格需要缴税的和。小 S 手头有 \(K\) 块钱,他想知道他最多能够买下多大面积的地,并且想知道所有满足要求的地中缴税最少的一块地所要缴的税。注意他能买的一块地只能是一个矩形。

形式化题意: 有一个 \(n\times m\) 的矩阵,在 \((i,j)\) 上的元素有一个权值 \(c_{i,j}\),你想知道能够选出权值和 \(\leqslant K\) 的所有子矩阵中包含最多元素的矩阵的元素个数以及在满足元素个数最大的条件下这个子矩阵中权值和的最小值。

数据范围:\(t\) 组数据,\(1\leqslant t\leqslant 110\),\(1\leqslant n,m\leqslant 10^9\),\(1\leqslant K\leqslant 10^9\),\(1\leqslant c_{i,j}\leqslant 10^6\)。

Solution

思路简单的二维前缀和问题。

我们先通过 \(\mathcal O(nm)\) 的复杂度把 \(s_{i,j}=\sum\limits_{x=1}^i\sum\limits_{y=1}^j c_{i,j}\) 预处理出来。当然 \(\mathcal O(n^2m^2)\) 的暴力计算在本题中貌似也可以,但还是讲讲前缀和怎么处理吧。

通过这个图我们不难发现,其中红色的部分是 \(s_{i-1,j}+s_{i,j-1}\) 而导致的重复的部分,也就是 \(s_{i-1,j-1}\),需要减一个。

因此可以很容易推出来 \(s_{i,j}=s_{i-1,j}+s_{i,j-1}-s_{i-1,j-1}+c_{i,j}\)。

然后我们再直接暴力枚举选取的矩阵的左上角 \((i_1,j_1)\) 和右下角 \((i_2,j_2)\)。然后这块地的 \(\sum\limits_i\sum\limits_jc_{i,j}\) 的公式推导类似于上面,只不过先要减去两个大的矩阵,再加回去两个矩阵重复减的部分。即为 \(s_{i_2,j_2}-s_{i_1-1,j_2}-s_{i_2,j_1-1}+s_{i_1-1,j_1-1}\)。面积倒很简单求,就是 \((i_2-i_1+1)(j_2-j_1+1)\)。然后拿它和当前的面积最大值进行比较:

  • 如果比当前最大面积小,那就想都不用想,直接跳过。
  • 如果和当前最大面积一样(注意!!!这里如果直接看原题面容易被坑到,这也是我要在翻译里面把要求的东西解释的如此复杂的原因),不要直接跳过,要把这块地的价值和当前的在最大面积下的价值和最小值进行比较,如果比当前的在最大面积下的价值和最小值小的话需要更新!
  • 如果比当前最大面积小,更新面积,并且同时更新价值和最小值(因为现在有了新的最大面积,原来的最大面积下的价值和最小值就得要覆盖)。

最后把求出来的东西输出即可。

Code

int c[107][107];
ll s[107][107]; int main() {
int t = Rint;
F(int, test, 1, t) {
memset(s, 0ll, sizeof(s));
int n = Rint, m = Rint, ans = 0; ll k = Rll, cost = 0;
F(int, i, 1, n) F(int, j, 1, m) c[i][j] = Rint;
F(int, i, 1, n) F(int, j, 1, m) s[i][j] = s[i - 1][j] + s[i][j - 1] - s[i - 1][j - 1] + c[i][j];
F(int, i, 1, n) F(int, j, 1, m) F(int, i2, i, n) F(int, j2, j, m) {
ll p = s[i2][j2] - s[i - 1][j2] - s[i2][j - 1] + s[i - 1][j - 1];
if(p <= k) cost = (ans == (i2 - i + 1) * (j2 - j + 1) ? min(cost, p) : (ans < (i2 - i + 1) * (j2 - j + 1) ? p : cost)), ans = max(ans, (i2 - i + 1) * (j2 - j + 1));
}
printf("Case #%d: %d %lld\n", test, ans, cost);
}
return 0;
}

UVA11951 Area 题解的更多相关文章

  1. HPU周赛题目解析

    A - Wilbur and Swimming Pool Time Limit:1000MS     Memory Limit:262144KB     64bit IO Format:%I64d & ...

  2. Maximal Rectangle leetcode java

    题目: Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle containing all ones ...

  3. 【leetcode刷题笔记】Maximal Rectangle

    Given a 2D binary matrix filled with 0's and 1's, find the largest rectangle containing all ones and ...

  4. 【题解】CIRU - The area of the union of circles [SP8073] \ 圆的面积并 [Bzoj2178]

    [题解]CIRU - The area of the union of circles [SP8073] \ 圆的面积并 [Bzoj2178] 传送门: \(\text{CIRU - The area ...

  5. POJ1389:Area of Simple Polygons——扫描线线段树题解+全套代码注释

    http://poj.org/problem?id=1389 题面描述在二维xy平面中有N,1 <= N <= 1,000个矩形.矩形的四边是水平或垂直线段.矩形由左下角和右上角的点定义. ...

  6. 题解——面积(area.cpp)

    题目来源&题面简述: 思路与算法选择: 只有*里面的部分对我们有用,所以可以将 *号外的部分标记一下. 可以用著名的BFS大法实现此过程.(连通块) 连通块模板: #include<bi ...

  7. POJ 1927 Area in Triangle 题解

    link Description 给出三角形三边长,给出绳长,问绳在三角形内能围成的最大面积.保证绳长 \(\le\) 三角形周长. Solution 首先我们得知道,三角形的内切圆半径就是三角形面积 ...

  8. hdu 4946 Area of Mushroom(凸包)

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=4946 Area of Mushroom Time Limit: 2000/1000 MS (Java/Ot ...

  9. poj 1654 Area (多边形求面积)

    链接:http://poj.org/problem?id=1654 Area Time Limit: 1000MS   Memory Limit: 10000K Total Submissions:  ...

随机推荐

  1. Ubuntu下的磁盘管理

    采用fat的磁盘存储,插入后采用相同命令会出现sdb和sdb1 sdb:磁盘 sdb1:磁盘分区标号为1 命令 df:显示磁盘使用情况 du:查询某个文件的大小读 du-h 或du -h --max- ...

  2. [源码解析] PyTorch 分布式 Autograd (2) ---- RPC基础

    [源码解析] PyTorch 分布式 Autograd (2) ---- RPC基础 目录 [源码解析] PyTorch 分布式 Autograd (2) ---- RPC基础 0x00 摘要 0x0 ...

  3. 城市防汛应急管理智慧 Web GIS 可视化平台

    前言 今年第 17 号台风"狮子山"(热带风暴级)登陆海南岛,受"狮子山"影响,海南岛北半部地区出现暴雨到大暴雨.局地特大暴雨.台风带来的强风雨导致海南岛多地树 ...

  4. Python使用print打印时,展示内容不换行

    原理 Python的print()函数中参数end='' 默认为\n,所以会自动换行; 默认的print()函数: print(end='\n') 方案 Python 2: 在print语句的末尾加上 ...

  5. 电脑盘符为什么从C盘开始?A盘和B盘去哪了?

    虽然我们几乎每天都在跟电脑打交道,但是不知道大家有没有过疑惑,为什么电脑盘符是从C盘开始命名呢?有没有A盘和B盘??A盘和B盘去哪了??? 其实,A盘和B盘是真实存在的. 在早期的DOS时代,计算机的 ...

  6. 【模板】二分图最大匹配(匈牙利算法)/洛谷P3386

    题目链接 https://www.luogu.com.cn/problem/P3386 题目大意 给定一个二分图,其左部点的个数为 \(n\),右部点的个数为 \(m\),边数为 \(e\),求其最大 ...

  7. API 管理在云原生场景下的机遇与挑战

    作者 | 张添翼 来源 | 尔达Erda公众号 ​ 云原生下的机遇和挑战 标准和生态的意义 自从 Kubernetes v1.0 于 2015 年 7 月 21 日发布,CNCF 组织随后建立以来,其 ...

  8. Learning Spark中文版--第六章--Spark高级编程(2)

    Working on a Per-Partition Basis(基于分区的操作) 以每个分区为基础处理数据使我们可以避免为每个数据项重做配置工作.如打开数据库连接或者创建随机数生成器这样的操作,我们 ...

  9. 零基础学习java------day8------javabean编写规范,继承,static关键字,代码块,单例设计模式

    0. 今日内容提要 1. javabean书写规范 javabean:一个普通的类,用来描述事物的类,里面不包含任何的业务逻辑,只是用来存储数据. 比如:Teacher,Student,Mobile. ...

  10. 零基础学习java------day5------do....while循环、嵌套、方法(函数)

    1  do...while循环 格式 初始化语句; do { 循环体语句; 控制条件语句; }while(判断条件语句); 流程: 先执行初始化语句 再执行循环体语句 再执行条件控制语句 再做条件的判 ...