LeetCode 0598.区间加法 II:最小值

【LetMeFly】598.区间加法 II:最小值

力扣题目链接:https://leetcode.cn/problems/range-addition-ii/

给你一个 m x n 的矩阵 M和一个操作数组 op 。矩阵初始化时所有的单元格都为 0ops[i] = [ai, bi] 意味着当所有的 0 <= x < ai0 <= 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

解题方法:最小值

这道题很有意思,每次都是左上角的一小块加一。

最终最大整数的个数,不就是每次都被加一的那些元素么。

横纵坐标可以分开计算,对于横坐标,每次都覆盖掉的就是所有操作中在最小值;纵坐标同理。

文字描述不如代码描述,还不懂的话,看完代码就懂了。

  • 时间复杂度 O ( l e n ( o p s ) ) O(len(ops)) O(len(ops))
  • 空间复杂度 O ( 1 ) O(1) O(1)

AC代码

C++
cpp 复制代码
/*
 * @Author: LetMeFly
 * @Date: 2025-02-02 10:31:46
 * @LastEditors: LetMeFly.xyz
 * @LastEditTime: 2025-02-02 11:05:10
 */
class Solution {
public:
    int maxCount(int m, int n, vector<vector<int>>& ops) {
        for (vector<int>& op : ops) {
            m = min(m, op[0]);
            n = min(n, op[1]);
        }
        return m * n;
    }
};
Python
python 复制代码
'''
Author: LetMeFly
Date: 2025-02-02 11:06:10
LastEditors: LetMeFly.xyz
LastEditTime: 2025-02-02 11:07:44
'''
from typing import List

class Solution:
    def maxCount(self, m: int, n: int, ops: List[List[int]]) -> int:
        for a, b in ops:
            m = min(m, a)
            n = min(n, b)
        return m * n
Java
java 复制代码
/*
 * @Author: LetMeFly
 * @Date: 2025-02-02 11:08:09
 * @LastEditors: LetMeFly.xyz
 * @LastEditTime: 2025-02-02 11:08:11
 */
class Solution {
    public int maxCount(int m, int n, int[][] ops) {
        for (int[] op : ops) {
            m = Math.min(m, op[0]);
            n = Math.min(n, op[1]);
        }
        return m * n;
    }
}
Go
go 复制代码
/*
 * @Author: LetMeFly
 * @Date: 2025-02-02 11:09:24
 * @LastEditors: LetMeFly.xyz
 * @LastEditTime: 2025-02-02 11:10:27
 */
package main

func min_RA2(m, n int) int {
    if m < n {
        return m
    }
    return n
}

func maxCount(m int, n int, ops [][]int) int {
    for _, op := range ops {
        m = min_RA2(m, op[0])
        n = min_RA2(n, op[1])
    }
    return m * n
}

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

Tisfy:https://letmefly.blog.csdn.net/article/details/145418564

相关推荐
黛色正浓几秒前
leetCode-热题100-滑动窗口合集(JavaScript)
javascript·算法·leetcode
漫随流水17 分钟前
leetcode算法(145.二叉树的后序遍历)
数据结构·算法·leetcode·二叉树
Tony_yitao22 分钟前
22.华为OD机试真题:数组拼接(Java实现,100分通关)
java·算法·华为od·algorithm
2501_9418752824 分钟前
在东京复杂分布式系统中构建统一可观测性平台的工程设计实践与演进经验总结
c++·算法·github
sonadorje27 分钟前
梯度下降法的迭代步骤
算法·机器学习
漫随流水29 分钟前
leetcode算法(94.二叉树的中序遍历)
数据结构·算法·leetcode·二叉树
范纹杉想快点毕业1 小时前
嵌入式通信核心架构:从状态机、环形队列到多协议融合
linux·运维·c语言·算法·设计模式
智源研究院官方账号1 小时前
众智FlagOS 1.6发布,以统一架构推动AI硬件、软件技术生态创新发展
数据库·人工智能·算法·架构·编辑器·硬件工程·开源软件
开源之眼1 小时前
GitHub star和github Vue3 响应式选择指南:ref 与 reactive 加星该怎么用?
算法·github