【LeetCode】范围求和 IIJava 题解
题目描述
给定一个初始元素全部为 0,大小为 m*n 的矩阵 M 以及在 M 上的一系列更新操作。
操作用二维数组表示,其中的每个操作用一个含有两个正整数 a 和 b 的数组表示,含义是将所有符合 0 <= i < a 以及 0 <= j < b 的元素 M[i][j] 的值都增加 1。
在执行给定的一系列操作后,你需要返回矩阵中含有最大整数的元素个数。
复制代码
思路分析
今天的算法每日一题是数组类题目,具体是范围求和。阅读题目,这是一个二维数组,ops 是一个操作数组,使具体的数组值加一。
首先,我们可以使用朴素解法,定义数组 m, n。然后遍历 ops 这个操作数组,并使用 hashMap 记录出现的值和值的次数。这种方法占用了较大的空间,不能通过所有的测试用例。
仔细思考一下,朴素解法的最终要求的是 ops 的交集部分,我们可以直接求 ops 的交集,思路就是分别求出 x, y 的最小值,最终 x * y 即位答案。实现详细代码如下:
通过代码
朴素算法
复制代码
优化解法
复制代码
总结
朴素解法的时间复杂度是 O(m * n), 空间复杂度 O(m * n)
优化解法的时间复杂度是 O(m * n), 空间复杂度 O(1)
坚持算法每日一题,加油!
版权声明: 本文为 InfoQ 作者【HQ数字卡】的原创文章。
原文链接:【http://xie.infoq.cn/article/f66e15786a67e89d19476b2fc】。文章转载请联系作者。
评论