【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
}
相关推荐
June bug1 天前
(#字符串处理)字符串中第一个不重复的字母
python·leetcode·面试·职场和发展·跳槽
AlenTech1 天前
197. 上升的温度 - 力扣(LeetCode)
算法·leetcode·职场和发展
源代码•宸1 天前
Leetcode—404. 左叶子之和【简单】
经验分享·后端·算法·leetcode·职场和发展·golang·dfs
WBluuue1 天前
数据结构与算法:dp优化——优化尝试和状态设计
c++·算法·leetcode·动态规划
im_AMBER1 天前
Leetcode 105 K 个一组翻转链表
数据结构·学习·算法·leetcode·链表
sin_hielo1 天前
leetcode 1877
数据结构·算法·leetcode
睡不醒的kun1 天前
定长滑动窗口-基础篇(2)
数据结构·c++·算法·leetcode·职场和发展·滑动窗口·定长滑动窗口
AI科技星1 天前
张祥前统一场论的数学表述与概念梳理:从几何公设到统一场方程
人工智能·线性代数·算法·机器学习·矩阵·数据挖掘
程序员-King.1 天前
day167—递归—二叉树的直径(LeetCode-543)
算法·leetcode·深度优先·递归
芒克芒克1 天前
LeetCode 134. 加油站(O(n)时间+O(1)空间最优解)
java·算法·leetcode·职场和发展