【Golang】LeetCode 1351. 统计有序矩阵中的负数

1351. 统计有序矩阵中的负数

题目描述

思路

这是2025 / 12 / 28的每日一题,使用双重循环暴力穷举的方式当然可以直接解题,但是题目要求我们思考一种`O(n+m)O(n + m)O(n+m)的解决方案,因此我们使用时间复杂度为O(n+m)O(n + m)O(n+m)的方案解题。

需要注意一条题目中提到的性质,那就是数组grid无论是从行还是从列的角度来观察,都是严格单调不增 的。这给了我们一条思路,那就是我们是否可以从"副对角线"出发,在每一行找到"负数"的起点,并将负数起点到行末这一段数的个数累加到答案当中?答案是可以的 。原因在于,由于数组无论从行还是从列都是单调不减的,如果grid[i][j] < 0,并且j是这一行第一个负数,那么一定有grid[i + 1][j] < 0grid[i + 1][j] < grid[i][j],因此i + 1这一行负数的起点至少是j,也可能是j - 1或更前面的下标。

基于上述性质,我们从副对角线出发设置一个变量pos,用于记录每一行第一个负数出现的位置,至上而下pos最多移动m次,还需要对行进行遍历,也就是n次,最终的时间复杂度就是O(n+m)O(n + m)O(n+m)。

Golang 题解

go 复制代码
func countNegatives(grid [][]int) int {
    n := len(grid[0])
    pos := n - 1
    ans := 0
    for _, row := range grid {
        i := pos
        for ; i >= 0; i -- {
            if row[i] >= 0 {
                if i + 1 < n {
                    pos = i + 1
                    ans += n - pos
                }
                break
            }
        }
        if i == -1 {
            pos = -1
            ans += n
        }
    }
    return ans
}
相关推荐
_深海凉_1 小时前
LeetCode热题100- 字母异位词分组
leetcode
洛水水1 小时前
【力扣100题】14.两数相加
c++·算法·leetcode
float_com1 小时前
LeetCode80. 删除有序数组中的重复项 II
leetcode
pwn蒸鱼1 小时前
leetcode:21. 合并两个有序链表
算法·leetcode·链表
洛水水1 小时前
【力扣100题】15.删除链表的倒数第 N 个结点
算法·leetcode·链表
wfbcg1 小时前
每日算法练习:LeetCode 3. 无重复字符的最长子串 ✅
算法·leetcode·职场和发展
_日拱一卒1 小时前
LeetCode:矩阵置零
java·数据结构·线性代数·算法·leetcode·职场和发展·矩阵
穿条秋裤到处跑2 小时前
每日一道leetcode(2026.04.10):三个相等元素之间的最小距离 I
算法·leetcode
学习永无止境@2 小时前
MATLAB中矩阵转置
算法·matlab·fpga开发·矩阵
玛丽莲茼蒿2 小时前
Leetcode hot100 【中等】括号生成
算法·leetcode·职场和发展