class Solution {
public:
int maxCount(int m, int n, vector<vector<int>>& ops) {
}
};
598. 范围求和 II
给你一个 m x n
的矩阵 M
,初始化时所有的 0
和一个操作数组 op
,其中 ops[i] = [ai, bi]
意味着当所有的 0 <= x < ai
和 0 <= y < bi
时, M[x][y]
应该加 1。
在 执行完所有操作后 ,计算并返回 矩阵中最大整数的个数 。
示例 1:
输入: m = 3, n = 3,ops = [[2,2],[3,3]] 输出: 4 解释: M 中最大的整数是 2, 而且 M 中有4个值为2的元素。因此返回 4。
示例 2:
输入: m = 3, n = 3, ops = [[2,2],[3,3],[3,3],[3,3],[2,2],[3,3],[3,3],[3,3],[2,2],[3,3],[3,3],[3,3]] 输出: 4
示例 3:
输入: m = 3, n = 3, ops = [] 输出: 9
提示:
1 <= m, n <= 4 * 104
0 <= ops.length <= 104
ops[i].length == 2
1 <= ai <= m
1 <= bi <= n
相似题目
原站题解
golang 解法, 执行用时: 8 ms, 内存消耗: 3.7 MB, 提交时间: 2021-07-02 14:46:02
func maxCount(m int, n int, ops [][]int) int { x, y := m, n for _, op := range ops { x, y = min(op[0], x), min(op[1], y) } return x * y } func min(x, y int) int { if x > y { return y } return x }