LeetCode 1351.统计有序矩阵中的负数:O(m+n)时间复杂度——抽象题解

【LetMeFly】1351.统计有序矩阵中的负数:O(m+n)时间复杂度------抽象题解

力扣题目链接:https://leetcode.cn/problems/count-negative-numbers-in-a-sorted-matrix/

给你一个 m * n 的矩阵 grid,矩阵中的元素无论是按行还是按列,都以非严格递减顺序排列。 请你统计并返回 grid负数 的数目。

示例 1:

复制代码
输入:grid = [[4,3,2,-1],[3,2,1,-1],[1,1,-1,-2],[-1,-1,-2,-3]]
输出:8
解释:矩阵中共有 8 个负数。

示例 2:

复制代码
输入:grid = [[3,2],[1,0]]
输出:0

提示:

  • m == grid.length
  • n == grid[i].length
  • 1 <= m, n <= 100
  • -100 <= grid[i][j] <= 100

进阶: 你可以设计一个时间复杂度为 O(n + m) 的解决方案吗?

解题方法:遍历

例如样例数组:

复制代码
 4  3  2 -1
 3  2  1 -1
 1  1 -1 -2
-1 -1 -2 -3

不难发现其实是这样的:

复制代码
 4  3  2  |  -1
 3  2  1 /  -1
 1  1   / -1 -2
-------+
-1 -1 -2 -3

看到中间那条分隔线了吗?我们按照中间那条线遍历就好了。

使用一个纵坐标变量,默认值为最后一列。接着从第一行开始往下遍历:

对于当前行,让纵坐标移动到第一个非负数的位置(或移出数组)。具体而言:

对于当前行,在纵坐标没有越界且当前所指元素为负数时,纵坐标不断左移。

  • 时间复杂度 O ( m + n ) O(m+n) O(m+n)
  • 空间复杂度 O ( 1 ) O(1) O(1)

AC代码

C++
cpp 复制代码
/*
 * @LastEditTime: 2025-12-28 14:45:14
 */
class Solution {
public:
    int countNegatives(vector<vector<int>>& grid) {
        int ans = 0;
        int n = grid.size(), m = grid[0].size();
        for (int i = 0, j = m - 1; i < n; i++) {
            while (j >= 0 && grid[i][j] < 0) {
                j--;
            }
            ans += m - j - 1;
        }
        return ans;
    }
};

/*
[[4,3,2,-1],
 [3,2,1,-1],
 [1,1,-1,-2],
 [-1,-1,-2,-3]]
*/

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

千篇源码题解已开源

相关推荐
扶摇接北海17614 分钟前
洛谷:P1104 生日
算法
旖-旎19 分钟前
二分查找(寻找旋转排序数组中的最小值)(7)
c++·算法·二分查找·力扣
C羊驼20 分钟前
C/C++数据结构与算法:穷举法
c语言·c++·笔记·学习·算法
guoji778820 分钟前
Gemini 3.1 Pro 安全与对齐机制深度解析:可控性、合规性与企业级应用评估
大数据·人工智能·算法
小则又沐风a22 分钟前
[蓝桥杯 2014 省 AB] 蚂蚁感冒
算法·职场和发展·蓝桥杯
IT猿手1 小时前
基于强化学习Q-learning算法的无人机三维路径规划算法原理与实现,MATLAB代码
算法·matlab·无人机·路径规划·动态路径规划
qq_417695051 小时前
C++中的解释器模式
开发语言·c++·算法
y = xⁿ1 小时前
【LeetCodehot100】T108:将有序数组转换为二叉搜索树 T98:验证搜索二叉树
数据结构·算法·leetcode
程序员小崔日记1 小时前
一道KMP统考真题彻底讲透:nextval与滑动距离的本质
算法·408·王道计算机考研
xiaoye-duck1 小时前
《算法题讲解指南:动态规划算法--路径问题》--9.最小路径和,10.地下城游戏
c++·算法·动态规划