栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

LeetCode-每日一题 598. 范围求和 II [Java实现] [极速] [极简]​

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

LeetCode-每日一题 598. 范围求和 II [Java实现] [极速] [极简]​

给定一个初始元素全部为 0,大小为 m*n 的矩阵 M 以及在 M 上的一系列更新操作。

操作用二维数组表示,其中的每个操作用一个含有两个正整数 a 和 b 的数组表示,含义是将所有符合 0 <= i < a 以及 0 <= j < b 的元素 M[i][j] 的值都增加 1。

在执行给定的一系列操作后,你需要返回矩阵中含有最大整数的元素个数。

示例 1:

输入: 
m = 3, n = 3
operations = [[2,2],[3,3]]
输出: 4
解释: 
初始状态, M = 
[[0, 0, 0],
 [0, 0, 0],
 [0, 0, 0]]

执行完操作 [2,2] 后, M = 
[[1, 1, 0],
 [1, 1, 0],
 [0, 0, 0]]

执行完操作 [3,3] 后, M = 
[[2, 2, 1],
 [2, 2, 1],
 [1, 1, 1]]

M 中最大的整数是 2, 而且 M 中有4个值为2的元素。因此返回 4。


方法一:观察

        看上去有点吓人,仔细思考下这句话:将所有符合 0 <= i < a 以及 0 <= j < b 的元素 M[i][j] 的值都增加 1 。诶?这意思是不是说结果的范围边界始终在 [0, min_operations] 之间!那么既然如此我们可以很迅速的给出如下代码:

    public int maxCount(int m, int n, int[][] ops) {
        int minx = m, miny = n;
        for (int[] op : ops) {
            minx = Math.min(minx, op[0]);
            miny = Math.min(miny, op[1]);
        }
        return minx * miny;
    }

                ​​​​​​​        ​​​​​​​        

最后,祝 EDG 夺冠!

为众人抱薪者,不可使其冻毙于风雪!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/439681.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号