leetcode 二分查找·系统掌握 统计有序矩阵中的负数

题目:

给你一个 m * n 的矩阵 grid,矩阵中的元素无论是按行还是按列,都以非严格递减顺序排列。 请你统计并返回 grid负数 的数目。

题解:

一种可行的解题思路是找出每一行中负数的个数再相加,又因为每一行单调递减,我们查找的又是负数,所以使用和上一题一样的泛型二分~01~模型,把每一行的结果相加即可。

cpp 复制代码
 int countNegatives(vector<vector<int>>& grid) {
        int ans=0;
        for(int i=0;i<grid.size();i++){
            int l=0,r=grid[0].size()-1;
            while(l<r){
                int mid=(l+r)>>1;
                if(grid[i][mid]<0)r=mid;
                else l=mid+1;
            }
            if(grid[i][l]<0)ans+=grid[0].size()-l;
        }
        return ans;
    }
相关推荐
得物技术20 分钟前
得物社区搜推公式融合调参框架-加乘树3.0实战
算法
会员源码网19 小时前
使用`mysql_*`废弃函数(PHP7+完全移除,导致代码无法运行)
后端·算法
木心月转码ing20 小时前
Hot100-Day10-T438T438找到字符串中所有字母异位词
算法
HelloReader21 小时前
Wi-Fi CSI 感知技术用无线信号“看见“室内的人
算法
颜酱1 天前
二叉树分解问题思路解题模式
javascript·后端·算法
qianpeng8971 天前
水声匹配场定位原理及实验
算法
董董灿是个攻城狮2 天前
AI视觉连载8:传统 CV 之边缘检测
算法
AI软著研究员2 天前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish2 天前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
颜酱2 天前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法