【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
}
相关推荐
人道领域7 小时前
【LeetCode刷题日记】47.全排列Ⅱ
java·开发语言·算法·leetcode
Navigator_Z7 小时前
LeetCode //C - 1095. Find in Mountain Array
c语言·算法·leetcode
AI_yangxi10 小时前
短视频矩阵系统供应商
大数据·人工智能·矩阵
暖阳华笺12 小时前
【数据结构与算法】哈希专题
数据结构·c++·算法·leetcode·哈希算法
AKA__Zas12 小时前
芝士算法(滑动窗口片 2.0)
java·算法·leetcode·学习方法
四代水门12 小时前
LeetCode刷算法题(C++)
c++·算法·leetcode
菜鸡爱玩16 小时前
线性代数矩阵相乘
线性代数·算法·矩阵
退休倒计时1 天前
【每日一题】LeetCode 53. 最大子数组和 TypeScript
数据结构·算法·leetcode·typescript
洛水水1 天前
【力扣100题】86.柱状图中最大的矩形
算法·leetcode·职场和发展
洛水水1 天前
【力扣100题】81.寻找两个正序数组的中位数
数据结构·算法·leetcode