目录

统计有序矩阵中的负数

统计有序矩阵中的负数

描述

给你一个 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

示例 3:
输入:grid = [[1,-1],[-1,-1]]
输出:3

示例 4:
输入:grid = [[-1]]
输出:1

代码

最简单的就是暴力破解,但是这个因为有序,所以当我们找到是负数的时候,直接后面可以不判断了

复制代码
class Solution(object):
    def countNegatives(self, grid):
        count = 0
        for i in range(len(grid)):
            for j in range(len(grid[0])):
                if grid[i][j] < 0:
                    count += len(grid[0]) - j
                    break
        return count

当然因为是不递增的,我们还可以想到使用二分查找法,时间复杂度是 O(logn)

复制代码
class Solution(object):
    def getIndex(self, line):
        lineLen = len(line)
        left = 0
        right = lineLen - 1

        while left <= right:
            mid = (left + right) // 2
            if line[mid] < 0 and ((mid != 0 and line[mid -1] >= 0) or (mid == 0)):
                return lineLen - mid
            elif line[mid] < 0:
                right = mid -1
            else:
                left = mid + 1
        return 0

    def countNegatives(self, grid):
        count = 0
        for i in range(len(grid)):        
            count += self.getIndex(grid[i])
        return count
本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
爱数模的小驴1 小时前
2025 年“认证杯”数学中国数学建模网络挑战赛 C题 化工厂生产流程的预测和控制
深度学习·算法·计算机视觉
序属秋秋秋3 小时前
算法基础_数据结构【单链表 + 双链表 + 栈 + 队列 + 单调栈 + 单调队列】
c语言·数据结构·c++·算法
apcipot_rain3 小时前
【密码学——基础理论与应用】李子臣编著 第五章 序列密码 课后习题
算法·密码学
不要不开心了4 小时前
sparkcore编程算子
pytorch·分布式·算法·pygame
88号技师4 小时前
【2024年最新IEEE Trans】模糊斜率熵Fuzzy Slope entropy及5种多尺度,应用于状态识别、故障诊断!
人工智能·算法·matlab·时序分析·故障诊断·信息熵·特征提取
清同趣科研4 小时前
R绘图|6种NMDS(非度量多维分析)绘图保姆级模板——NMDS从原理到绘图,看师兄这篇教程就够了
人工智能·算法
杜小暑4 小时前
冒泡排序与回调函数——qsort
c语言·算法·排序算法
徵6864 小时前
代码训练day27贪心算法p1
算法·贪心算法
Nigori7_5 小时前
day32-动态规划__509. 斐波那契数__70. 爬楼梯__746. 使用最小花费爬楼梯
算法·动态规划
x_feng_x5 小时前
数据结构与算法 - 数据结构与算法进阶
数据结构·python·算法