力扣【598-区间加法】【数组-C语言】

题目:力扣-598

给你一个 m x n 的矩阵 M 和一个操作数组 ops 。矩阵初始化时所有的单元格都为 0 。ops[i] = [ai, bi] 意味着当所有的 0 <= x < ai 和 0 <= y < bi 时, M[x][y] 应该加 1。在 执行完所有操作后 ,计算并返回 矩阵中最大整数的个数 。

题目理解:自己初始化一个m*n阶元素全0的矩阵,而ops是一个二维数组,ops的每个元素是一个" int* "类型,它指向一个长度为2的一维数组的首元素,该一维数组中两个整型元素分别为x,y,并在矩阵M中找到0 ~ x行,0 ~ y列的所有元素增加1,每遍历一个ops元素(一维数组)就给矩阵M相应的行、列元素增加1。遍历操作结束,则计算矩阵M中最大元素的个数

cpp 复制代码
int maxCount(int m, int n, int** ops, int opsSize, int* opsColSize) {
    if(!opsSize) return m*n;
    //记录最大整数的行,列数
    int maxr=ops[0][0];
    int maxc=ops[0][1];
    //遍历ops矩阵
    for(int i=1;i<opsSize;i++){
        maxr=(maxr>ops[i][0])?ops[i][0]:maxr;
        maxc=(maxc>ops[i][1])?ops[i][1]:maxc;
    }
    return maxr*maxc;
}

时间复杂度:O(n),其中 n 是数组 ops 的长度。

空间复杂度:O(1)。

相关推荐
田梓燊4 分钟前
leetcode 142
android·java·leetcode
CoovallyAIHub9 分钟前
混合训练反而更差?VLM Agent在训练前协调跨数据集标注,文档布局检测F-score从0.860提升至0.883
算法·架构·github
talen_hx29610 分钟前
《零基础入门Spark》学习笔记 Day 16
笔记·学习·spark
鸿途优学-UU教育11 分钟前
教材质量——法考培训的根基与底气
算法
_深海凉_24 分钟前
LeetCode热题100-最大数(179)
算法·leetcode·职场和发展
咬_咬37 分钟前
go语言学习(map)
开发语言·学习·golang·map
克里斯蒂亚诺·罗纳尔达42 分钟前
智能体学习21——知识检索(RAG)
人工智能·学习·ai
Jackyzhe44 分钟前
从零学习Kafka:认证机制
分布式·学习·kafka
剑挑星河月1 小时前
763.划分字母区间
数据结构·算法·leetcode
深蓝海拓1 小时前
基于QtPy (PySide6) 的PLC-HMI工程项目(八)在上位机中解析上行报文
网络·笔记·python·学习·plc