q:
給定乙個初始元素全部為0,大小為 m*n 的矩陣m以及在m上的一系列更新操作。
操作用二維陣列表示,其中的每個操作用乙個含有兩個正整數 a和b的陣列表示,含義是將所有符合0 <= i < a以及0 <= j < b的元素m[i][j]的值都增加 1。
在執行給定的一系列操作後,你需要返回矩陣中含有最大整數的元素個數。
示例 1:
輸入:m = 3, n = 3思路:實際就是ops最小範圍與 ops運算元個數的乘積,**如下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。
更高效一些的**:
class solution(object):
def maxcount(self, m, n, ops):
""":type m: int
:type n: int
:type ops: list[list[int]]
:rtype: int
"""if not ops:
return m*n
return min(op[0] for op in ops)*min(op[1] for op in ops)
LeetCode 598 範圍求和2
給定乙個初始元素全部為 0,大小為 m n 的矩陣 m 以及在 m 上的一系列更新操作。操作用二維陣列表示,其中的每個操作用乙個含有兩個正整數 a 和 b 的陣列表示,含義是將所有符合 0 i a 以及 0 j b 的元素 m i j 的值都增加 1。在執行給定的一系列操作後,你需要返回矩陣中含有最...
LeetCode 598 範圍求和 II
難度 簡單 給定乙個初始元素全部為 0,大小為 m n 的矩陣 m 以及在 m 上的一系列更新操作。操作用二維陣列表示,其中的每個操作用乙個含有兩個正整數 a 和 b 的陣列表示,含義是將所有符合 0 i a 以及 0 j b 的元素 m i j 的值都增加 1。在執行給定的一系列操作後,你需要返回...
LeetCode 598 範圍求和 II
從0開始刷力扣,第十六天。598.範圍求和 ii 給定乙個初始元素全部為 0,大小為 m n 的矩陣 m 以及在 m 上的一系列更新操作。操作用二維陣列表示,其中的每個操作用乙個含有兩個正整數 a 和 b 的陣列表示,含義是將所有符合 0 i a 以及 0 j b 的元素 m i j 的值都增加 1...