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;
    }
相关推荐
fff9811187 小时前
C++与Qt图形开发
开发语言·c++·算法
计算机安禾7 小时前
【数据结构与算法】第3篇:C语言核心机制回顾(二):动态内存管理与typedef
c语言·开发语言·数据结构·c++·算法·链表·visual studio
njidf7 小时前
C++中的访问者模式
开发语言·c++·算法
C_Si沉思8 小时前
C++中的工厂模式变体
开发语言·c++·算法
C羊驼8 小时前
C语言学习笔记(十五):预处理
c语言·经验分享·笔记·学习·算法
m0_569881478 小时前
C++中的适配器模式变体
开发语言·c++·算法
NAGNIP8 小时前
面试官:正则化都有哪些经典的方法?
算法·面试
Theodore_10229 小时前
深度学习(12)正则化线性回归中的偏差与方差调试
人工智能·深度学习·算法·机器学习·线性回归
m0_569881479 小时前
跨语言调用C++接口
开发语言·c++·算法
老鼠只爱大米9 小时前
LeetCode经典算法面试题 #295:数据流的中位数(双堆法、有序列表、平衡树等多种实现方案详解)
算法·leetcode·优先队列··数据流·中位数·java 面试题