统计有序矩阵中的负数

统计有序矩阵中的负数

描述

给你一个 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
相关推荐
sali-tec27 分钟前
C# 基于halcon的视觉工作流-章32-线线测量
开发语言·人工智能·算法·计算机视觉·c#
lingran__36 分钟前
速通ACM省铜第一天 赋源码(The Cunning Seller (hard version))
c++·算法
塔中妖44 分钟前
【华为OD】数字游戏
算法·游戏·华为od
pzx_0011 小时前
【LeetCode】392.判断子序列
算法·leetcode·职场和发展
沐怡旸1 小时前
【算法--链表】146.LRU缓存--通俗讲解
算法·面试
京东零售技术1 小时前
查收你的技术成长礼包
后端·算法·架构
fangzelin52 小时前
算法-滑动窗口
数据结构·算法
zcz16071278213 小时前
LVS + Keepalived 高可用负载均衡集群
java·开发语言·算法
rit84324993 小时前
人工鱼群算法AFSA优化支持向量机SVM,提高故障分类精度
算法·支持向量机·分类